leetcode-22-string

Posted pxy7896

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了leetcode-22-string相关的知识,希望对你有一定的参考价值。

 521. Longest Uncommon Subsequence I

find the longest uncommon subsequence of this group of two strings

解题思路:

因为求的是最长uncommon subsequence的长度,所以,如果ab长度不等,应返回长度较大值;ab相同,则返回-1;否则返回长度即可。

int findLUSlength(string a, string b) {
        if (a == b)
            return -1;
        if (a.size() != b.size())
            return a.size() > b.size() ? a.size() : b.size();
        return a.size();
    }

392. Is Subsequence

Given a string s and a string t, check if s is subsequence of t.

解题思路:直接扫一遍t检查就好了。。注意,如果s已经找完,应该跳出循环,不然会runtime error

bool isSubsequence(string s, string t) {
        int i, j;
        for (i = 0, j = 0; i < t.length(); i++) {
            if (j == s.length())
                break;
            if (t[i] == s[j])
                j++;
        }
        return j == s.length();
    }

 541. Reverse String II

解题思路:

其实是以2k为一组,翻转前i个(i<=k)。所以对于长度为2k的正常翻转,最后一组考虑长度<k的情况。另外,对于k>s.length()时,要翻转

整个s。

string reverseStr(string s, int k) {
        if (s.length() < 2 || k == 0 )
            return s;
        string result = s;
        bool flag = false;
        int i;
        if (s.length() <= k) {
            flag = true;
            i = 0;
        }
        //int i;
        if (flag == false) {
        for (i = 0; i < s.length(); i = i + 2 * k) {
            int m = i;
            int n = i + k - 1;
            if (n >= s.length()) {
                flag = true;
                break;
            }
            int temp;
            while (m <= n) {
                temp = result[m];
                result[m] = result[n];
                result[n] = temp;
                m ++;
                n --;
            }
        }
        }
        if (flag == true) {
                int m = i;
                int n = s.length()-1;
                int temp;
            while (m <= n) {
                temp = result[m];
                result[m] = result[n];
                result[n] = temp;
                m ++;
                n --;
            }
            }
        return result;
    }

  

 

以上是关于leetcode-22-string的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段——CSS选择器

谷歌浏览器调试jsp 引入代码片段,如何调试代码片段中的js

片段和活动之间的核心区别是啥?哪些代码可以写成片段?

VSCode自定义代码片段——.vue文件的模板

VSCode自定义代码片段6——CSS选择器

VSCode自定义代码片段——声明函数