最长公共前缀

  1. 最长公共前缀 编写一个函数来查找字符串数组中的最长公共前缀。

如果不存在公共前缀,返回空字符串 “”。

示例 1:

输入:strs = [“flower”,“flow”,“flight”] 输出:“fl” 示例 2:

输入:strs = [“dog”,“racecar”,“car”] 输出:"" 解释:输入不存在公共前缀。

提示:

1 <= strs.length <= 200 0 <= strs[i].length <= 200 strs[i] 仅由小写英文字母组成
通过次数630,227提交次数1,538,593 请问您在哪类招聘中遇到此题? 贡献者 LeetCode

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleApp2
{
    class Program
    {
        static void Main(string[] args)
        {
            string[] strs = { "dog","racecar","car"};
            string a = LongestCommonPrefix(strs);

                Console.WriteLine(a);
                Console.ReadLine();
 

        }
        static public string LongestCommonPrefix(string[] strs)
        {
            int i = 1;
            bool flag = false;
            int shortestWordLength = strs.Min(w => w.Length);
            if (shortestWordLength == 1)
            {

                for (int m = 1; m < strs.Length; m++)
                {
                    if (strs[m].Substring(0, 1) != strs[m - 1].Substring(0, 1))
                    {
                        return "";
                    }

                }
                return strs[0].Substring(0, 1);
            }
            else
            {
                while (i <= shortestWordLength)
                {
                    for (int m = 1; m < strs.Length; m++)
                    {
                        if (strs[m].Substring(0, i) != strs[m - 1].Substring(0, i))
                        {
                            flag = true;


                        }

                    }

                    if (flag == true)
                    {
                        break;
                    }
                    i++;
                }
                if (strs[0].Substring(0, i - 1) == "")
                {
                    return "";
                }
                else
                return strs[0].Substring(0, i - 1);
            }
        }

    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值