leetcode 14. 最長公共前綴

編寫一個函數來查找字符串數組中的最長公共前綴。

如果不存在公共前綴,返回空字符串 ""

示例 1:

輸入: ["flower","flow","flight"]
輸出: "fl"

示例 2:

輸入: ["dog","racecar","car"]
輸出: ""
解釋: 輸入不存在公共前綴。

在這裏插入圖片描述

簡單解析:就是尋找最長公共前綴,第一反應是直接比較和Trie樹都行,然後直接比較了,這樣簡單點。

class Solution {
public:
    string longestCommonPrefix(vector<string>& strs) {
        if(strs.size() == 0) return "";
        string ans = strs[0];
        int cnt = 0;
        for (int i = 1; i < strs.size(); ++i) {
            string str = strs[i];
            int flag = 0;
            for (int j = 0; j < str.length() && j < ans.length(); j++) {
                if(ans[j] != str[j]) {
                    ans = ans.substr(0, j);
                    flag = 1;
                    break;
                }
            }
            if(!flag) {
                if(ans.length() > str.length()) ans = str;
            }
        }
        return ans;
    }
};
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章