leetcode轮回计划20180902

  1. 1 Two Sum
    思路:map
  2. 2 Add Two Numbers
    题意:两个数字按照链表表示,返回表示两个数字之和的链表
    思路:直接求,考虑两个链表不同长度以及最后有进位的情况
  3. 3 Longest Substring Without Repeating Characters
    题意:求字符串中最长无重复字母子序列的长度
    思路:dp,一维表格,每个cell代表以当前字母结尾的无重复字母子串的长度
  4. 5 Longest Palindromic Substring
    题意: 字符串中最长回文子串的长度
    思路:构造特殊字符串,两个字母之间插入'#',再加上开头和结尾标志,这样可以规避回文串是奇数还是偶数的问题
    origin solution:
class Solution {
public:
    string longestPalindrome(string s) {
        if(s.size() == 0) return "";
        string tool = "$#";
        for(char a : s) tool = tool + a + '#';
        tool = tool + '*';
        int tmp_i = 2;
        int tmp_j = 0;
        for(int i = 2; i < tool.size() - 1; i ++){
            int j = 1;
            while(tool[i - j] == tool[i + j]){
                j ++;
            }
            if(tmp_j < j){
                tmp_i = i;
                tmp_j = j;
            }
        }
        string ret = "";
        for(int i = tmp_i - tmp_j + 2;i <= tmp_i + tmp_j - 2;i += 2){
            ret = ret + tool[i];
        }
        return ret;
    }
};

但是,这种解法的时间复杂度是n方,使用马拉车算法,可以将时间复杂度控制在n。以下是马拉车算法的ac代码。对马拉车算法解释地比较好的:https://blog.csdn.net/liuwei0604/article/details/50414542

public class Solution {
    public String longestPalindrome(String s) {
        if(s.length()<=1){
            return s;
        }
        // 预处理字符串,避免奇偶问题
        String str = preProcess(s);
        // idx是当前能够向右延伸的最远的回文串中心点,随着迭代而更新
        // max是当前最长回文串在总字符串中所能延伸到的最右端的位置
        // maxIdx是当前已知的最长回文串中心点
        // maxSpan是当前已知的最长回文串向左或向右能延伸的长度
        int idx = 0, max = 0;
        int maxIdx = 0;
        int maxSpan = 0;
        int[] p = new int[str.length()];
        for(int curr = 1; curr < str.length(); curr++){
            // 找出当前下标相对于idx的对称点
            int symmetryOfCurr = 2 * idx - curr;
            // 如果当前已知延伸的最右端大于当前下标,我们可以用对称点的P值,否则记为1等待检查
            p[curr] = max > curr? Math.min(p[symmetryOfCurr], max - curr):1;
            // 检查并更新当前下标为中心的回文串最远延伸的长度
            while((curr+p[curr])<str.length() && str.charAt(curr+p[curr])==str.charAt(curr-p[curr])){
                p[curr]++;
            }
            // 检查并更新当前已知能够延伸最远的回文串信息
            if(curr+p[curr]>max){
                max = p[curr] + curr;
                idx = curr;
            }
            // 检查并更新当前已知的最长回文串信息
            if(p[curr]>maxSpan){
                maxSpan = p[curr];
                maxIdx = curr;
            }
        }
        //去除占位符
        return s.substring((maxIdx-maxSpan)/2,(maxSpan+maxIdx)/2-1);
    }
    
    private String preProcess(String s){
        // 如ABC,变为$#A#B#C#
        StringBuilder sb = new StringBuilder();
        sb.append("$");
        for(int i = 0; i < s.length(); i++){
            sb.append("#");
            sb.append(s.charAt(i));
        }
        sb.append("#");
        return sb.toString();
    }
}

c++版本的:

class Solution {
public:
    string longestPalindrome(string s) {
        string t = "$#";
        for(auto a : s) t = t + a + '#';
        // cout<<t<<endl;
        
        int size = t.size();
        vector<int> dp(size, 0);
        int idx = 0, right = 0, maxIdx = 0, maxSpan = 0;
        for(int curr = 1; curr < size; curr ++){
            int flx = 2 * idx - curr;
            dp[curr] = right > curr ? min(dp[flx], right - curr) : 1;
            while((curr + dp[curr]) < size && t[curr - dp[curr]] == t[curr + dp[curr]]) dp[curr] ++;
            
            if(curr + dp[curr] > right){
                right = dp[curr] + curr;
                idx = curr;
            }
            if(dp[curr] > maxSpan){
                maxSpan = dp[curr];
                maxIdx = curr;
            }
        }
        
        // cout<<maxIdx<<' '<<maxSpan<<endl;
        // for(auto a : dp) cout<<a<<' ';
        // cout<<endl;
        return s.substr((maxIdx-maxSpan)/2,(maxSpan - 1));
    }
};
  1. 6 Zigzag Conversion
    题意:按照一种奇怪的顺序读取字符串,但是不能创建二维数组,因为空间限制。
    思路:按照每一行的顺序来进行读取,首先建立每个字母属于的行的映射。
  2. 7 Reverse Integer
    题意:将整数reverse。注意负数和数字太大或者太小的情况。
    思路:这种题目直接用long long 上就行了
class Solution {
public:
    int reverse(int x) {
        long long ret = 0;
        while(x != 0){
            ret = ret * 10 + x % 10;
            x /= 10;
        }
        return (ret < INT_MIN || ret > INT_MAX) ? 0 : ret;
    }
};
  1. 8 String to Integer
    题意:将字符串转换成数字
    思路:注意数字大小溢出的情况
    有点东西:str.find_first_not_of()isdigit()
  2. 9 Palindrome Number
    题意:判断整数是否是回文数
    思路:reverse这个数字。需要考虑负数情况。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容