Valid Palindrome

Given a string, determine if it is a palindrome, considering only alphanumeric characters and ignoring cases.

For example,
"A man, a plan, a canal: Panama" is a palindrome.
"race a car" is not a palindrome.

Note:
Have you consider that the string might be empty? This is a good question to ask during an interview.

For the purpose of this problem, we define empty string as valid palindrome.

处理好大小写转换、非法字符忽略就可以。

 class Solution {
public: bool isPalindrome(string s) {
if (s.empty()) return true;
int l = , r = s.length() - ;
char c1, c2;
while (r > l) {
while (true) {
if (l >= r) break;
if (s[l] >= 'a' && s[l] <= 'z') break;
if (s[l] >= 'A' && s[l] <= 'Z') { s[l] += ; break; }
if (s[l] >= '' && s[l] <= '') break;
l++;
} while (true) {
if (l >= r) break;
if (s[r] >= 'a' && s[r] <= 'z') break;
if (s[r] >= 'A' && s[r] <= 'Z') { s[r] += ; break; }
if (s[r] >= '' && s[r] <= '') break;
r--;
} if (s[l] != s[r]) return false;
l++; r--;
} return true;
}
};

这样写好一点。

 class Solution {
public:
bool isDigit(char c) {
return (c >= '' && c <= '');
} bool isUppercase(char c) {
return (c >= 'A' && c <= 'Z');
} bool isLowercase(char c) {
return (c >= 'a' && c <= 'z');
} bool isValid(char c) {
return (isLowercase(c) || isDigit(c) || isUppercase(c));
} bool isPalindrome(string s) {
if (s.empty()) return true;
int n = s.length();
for (int i = , j = n - ; i < j; ) {
for (; i < j && !isValid(s[i]); i++);
for (; i < j && !isValid(s[j]); j--);
if (isUppercase(s[i])) s[i] += ;
if (isUppercase(s[j])) s[j] += ;
if (s[i] != s[j]) return false;
i++, j--;
}
return true;
}
};

Palindrome Partitioning

Given a string s, partition s such that every substring of the partition is a palindrome.

Return all possible palindrome partitioning of s.

For example, given s = "aab",
Return

[
["aa","b"],
["a","a","b"]
]

回溯法就可以了。

 class Solution {
public: bool isPalindrome(string &s) {
int n = s.length();
if (n <= ) return true;
int l = , r = n - ;
while (r > l) {
if (s[l] != s[r]) return false;
r--; l++;
}
return true;
} vector<vector<string>> partition(string s) {
vector<vector<string>> rets; vector<string> ret;
bt(s, , ret, rets); return rets;
} void bt(string &s, int index, vector<string> &ret, vector<vector<string>> &rets) {
if (index >= s.length()) {
rets.push_back(ret);
return;
} for (int i = index; i < s.length(); ++i) {
string tmp(s.substr(index, i - index + ));
if (isPalindrome(tmp)) {
ret.push_back(tmp);
bt(s, i + , ret, rets);
ret.pop_back();
}
}
}
};

Palindrome Partitioning II

Given a string s, partition s such that every substring of the partition is a palindrome.

Return the minimum cuts needed for a palindrome partitioning of s.

For example, given s = "aab",
Return 1 since the palindrome partitioning ["aa","b"] could be produced using 1 cut.

这里主要有两层需要dp的。

1. 令p[i][j]为i到j之间需要的最小cut个数。我们要求的是p[0][n - 1]。第一个dp很简单,p[i][n - 1] = min{p[j+1][n-1]} + 1, 其中i<=j<n,s(i, j)是回文。

2. 判断回文其实也是一个dp的过程,不过每次都用循环。如果s(i, j)是回文,则p[i][j]=0。p[i][j] = 0 当且仅当str[i]== str[j] && p[i + 1][j - 1]=0。没有这一部分dp就会TLE了。这一步骤用递归就可以,注意的是,比较后要设置p[i][j],无论是否等于0.

 class Solution {
public:
bool isPalindrome(string &s, int l, int r, vector<vector<int> > &p) {
if (l > r) return true;
if (p[l][r] == ) return true;
if (p[l][r] != -) return false;
if (s[l] != s[r]) return false; bool isPalin = isPalindrome(s, l + , r - , p);
if (isPalin) {
p[l][r] = ;
} else {
p[l][r] = r - l;
}
return isPalin;
} int minCut(string s) {
int n = s.length();
if (n <= ) return ;
vector<vector<int> > p(n, vector<int>(n, -));
for (int i = ; i < n; ++i) {
p[i][i] = ;
}
for (int i = n - ; i >= ; --i) {
p[i][n - ] = n - i - ;
for (int j = i; j < n; ++j) {
if (s[j] == s[i] && isPalindrome(s, i + , j - , p)) {
p[i][j] = ; if (j < n - && p[j + ][n - ] + < p[i][n - ]) {
p[i][n - ] = p[j + ][n - ] + ;
}
}
}
} return p[][n - ];
}
};

第三次写,用了两个数组。不过思路也算简单了。

 class Solution {
public:
int minCut(string s) {
if (s.empty()) return ;
int n = s.length();
vector<vector<bool> > dp(n, vector<bool>(n, false));
vector<int> min(n, );
for (int i = ; i < n; ++i) {
dp[i][i] = true;
min[i] = min[i - ] + ;
for (int j = i - ; j >= ; --j) {
if ((j > i - || dp[j + ][i - ]) && s[i] == s[j]) {
dp[j][i] = true;
if (j == ) min[i] = ;
else if (min[j - ] + < min[i]) min[i] = min[j - ] + ;
}
}
}
return min[n - ];
}
};

空间上比起用vector<vector<int> >还是省了。因为用bool的话,最终用了O(n^2+n),用int虽然看起来只用了一个变量,但是却是O(4n^2)。

Leetcode | Palindrome的更多相关文章

  1. LeetCode:Palindrome Partitioning,Palindrome Partitioning II

    LeetCode:Palindrome Partitioning 题目如下:(把一个字符串划分成几个回文子串,枚举所有可能的划分) Given a string s, partition s such ...

  2. LeetCode: Palindrome Partition

    LeetCode: Palindrome Partition Given a string s, partition s such that every substring of the partit ...

  3. [LeetCode] Palindrome Partitioning II 解题笔记

    Given a string s, partition s such that every substring of the partition is a palindrome. Return the ...

  4. LeetCode: Palindrome 回文相关题目

    LeetCode: Palindrome 回文相关题目汇总 LeetCode: Palindrome Partitioning 解题报告 LeetCode: Palindrome Partitioni ...

  5. [LeetCode] Palindrome Pairs 回文对

    Given a list of unique words. Find all pairs of distinct indices (i, j) in the given list, so that t ...

  6. [LeetCode] Palindrome Permutation II 回文全排列之二

    Given a string s, return all the palindromic permutations (without duplicates) of it. Return an empt ...

  7. [LeetCode] Palindrome Permutation 回文全排列

    Given a string, determine if a permutation of the string could form a palindrome. For example," ...

  8. [LeetCode] Palindrome Linked List 回文链表

    Given a singly linked list, determine if it is a palindrome. Follow up: Could you do it in O(n) time ...

  9. [LeetCode] Palindrome Partitioning II 拆分回文串之二

    Given a string s, partition s such that every substring of the partition is a palindrome. Return the ...

  10. [LeetCode] Palindrome Partitioning 拆分回文串

    Given a string s, partition s such that every substring of the partition is a palindrome. Return all ...

随机推荐

  1. python chm 中文帮助 (2.7 和 3.4)

    sphinx-build 生成的(htmlhelp) 存在2个问题 1.生成的html 编码 cp2152,需要修改/sphinx/builders/html.py ctx['encoding'] = ...

  2. codeforces A. Domino 解题报告

    题目链接:http://codeforces.com/problemset/problem/353/A 题目意思:通俗地说,就是当上下两半的数的总和不完全是偶数时,通过上下调换某些骨牌来使这两半的数和 ...

  3. mybatis整合spring 之 基于接口映射的多对一关系

    转载自:http://my.oschina.net/huangcongmin12/blog/83731 mybatis整合spring 之  基于接口映射的多对一关系. 项目用到俩个表,即studen ...

  4. POJ1704 Georgia and Bob (阶梯博弈)

    Georgia and Bob Time Limit: 1000MS   Memory Limit: 10000KB   64bit IO Format: %I64d & %I64u Subm ...

  5. 安装绿色版mysql

    #修改my.ini basedir = "D:\tools\mysql-5.7.13-winx64" datadir = "D:\tools\mysql-5.7.13-w ...

  6. 队列——解密QQ号

    队列——解密QQ号 --转自啊哈磊[坐在马桶上看算法]算法4:队列——解密QQ号 新学期开始了,小哈是小哼的新同桌(小哈是个小美女哦~),小哼向小哈询问QQ号,小哈当然不会直接告诉小哼啦,原因嘛你懂的 ...

  7. yum rpm

    本文多选自鸟哥的私房菜,非常感谢鸟哥^_ _^

  8. register

    register:这个关键字请求编译器尽可能的将变量存在CPU内部寄存器中,而不是通过内存寻址访问,以提高效率.注意是尽可能,不是绝对.你想想,一个CPU 的寄存器也就那么几个或几十个,你要是定义了很 ...

  9. 一、HTML和CSS基础--网页布局--如何用css进行网页布局

    什么叫做布局? 又称版式布局,是网页UI设计师将有限的视觉元素进行有机的排列组合. 网页设计的特点 网页可以自适应宽度 网页的高度理论上可以无限延长 网页分栏 分栏又称为分列,常见的布局分为:一列布局 ...

  10. Java Hour 58 Java Virtual Machine

    每每谈到Java Virtual Machine, 你必须意识到这个有三种意思: 1 一个抽象的指南 2 一个具体的实现 3 一个运行时的实例 JVM 的生命周期 每个运行时JVM 实例都是为一个特定 ...