LeetCode : Longest Common Prefix [java]

Write a function to find the longest common prefix string amongst an array of strings.

思路:每两个串确定一个最长公共前缀,然后再拿和这个公共前缀和第三个串确定新的最长公共前缀,以此类推。

public class Solution {
	public String longestCommonPrefix(String[] strs) {
		if (strs == null || strs.length == 0) {
			return "";
		}
		if (strs.length == 1) {
			return strs[0];
		}
		String prefix = strs[0];
		for (int i = 1; i < strs.length; i++) {
			prefix = findCommonPrefix(prefix, strs[i]);
			if (prefix.equals("")) {
				return "";
			}
		}
		return prefix;
	}

	private String findCommonPrefix(String str1, String str2) {
		String prefix = "";
		int i = 0;
		while (i < str1.length() && i < str2.length() && str1.charAt(i) == str2.charAt(i)) {
			prefix += str1.charAt(i);
			i++;
		}
		return prefix;
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值