当前位置:网站首页>Swordsman Offer Special Assault Edition ---- Day 6
Swordsman Offer Special Assault Edition ---- Day 6
2022-07-31 05:32:00 【Milan's little red and black】
class Solution {
public String minWindow(String s, String t) {
int n = s.length(),m = t.length();
if(n<m) return "";
int[] cnt = new int[150];
int k = 0;
for(char c:t.toCharArray()){
if(++cnt[c]==1){
k++;
}
}
int l = 0,left = 0,right = 0;
for(int i = 0;i<s.length();i++){
char c = s.charAt(i);
if(--cnt[c]==0) k--;
if(k==0){
while(cnt[s.charAt(l)]<0){
++cnt[s.charAt(l++)];
}
if(left==right||right-left>i-l+1){
right = i+1;
left = l;
}
}
}
return s.substring(left,right);
}
}
class Solution {
public boolean isPalindrome(String s) {
StringBuilder str = new StringBuilder();
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
if (Character.isLetterOrDigit(c)) {
str.append(Character.toLowerCase(c));
}
}
return str.toString().equals(new StringBuffer(str).reverse().toString());
}
}
class Solution {
public boolean validPalindrome(String s) {
for(int left = 0, right = s.length() - 1; left < right; left++, right--){
// 如果不相等,则分两种情况:删除左边的元素,或者右边的元素,再判断各自是否回文,满足一种即可.
if(s.charAt(left) != s.charAt(right))
return isPalindrome(s, left+1, right) || isPalindrome(s, left, right - 1);
}
return true;
}
// 判断字符串 s 的 [left, right] 是否回文
private boolean isPalindrome(String s, int left , int right){
while (left < right){
if (s.charAt(left++) != s.charAt(right--))
return false;
}
return true;
}
}
class Solution {
public int countSubstrings(String s) {
int n = s.length(), ans = 0;
for (int i = 0; i < 2 * n - 1; ++i) {
int l = i / 2, r = i / 2 + i % 2;
while (l >= 0 && r < n && s.charAt(l) == s.charAt(r)) {
--l;
++r;
++ans;
}
}
return ans;
}
}
边栏推荐
猜你喜欢
剑指offer基础版--- 第23天
Anaconda configure environment directives
再见了繁琐的Excel,掌握数据分析处理技术就靠它了
pycharm专业版使用
剑指offer基础版 --- 第22天
The interviewer asked me how to divide the database and the table?Fortunately, I summed up a set of eight-part essays
【一起学Rust】Rust的Hello Rust详细解析
Centos7 install mysql5.7
Numpy中np.meshgrid的简单用法示例
一文了解大厂的DDD领域驱动设计
随机推荐
Redis的初识
关于LocalDateTime的全局返回时间带“T“的时间格式处理
Flask 的初识
剑指offer专项突击版 --- 第 3 天
Redis Advanced - Cache Issues: Consistency, Penetration, Penetration, Avalanche, Pollution, etc.
目标检测学习笔记
可点击也可直接复制指定内容js
Object Detection Study Notes
MySQL transaction isolation level, rounding
运用flask框架发送短信验证码的流程及具体代码
Workflow番外篇
C语言实验一 熟悉C程序的环境
CentOS7 - yum install mysql
pytorch中的一维、二维、三维卷积操作
C语言指针详解
Flink sink redis 写入Redis
Kubernetes 证书可用年限修改
Apache DButils使用注意事项--with modifiers “public“
torch.normal函数用法
基于flask的三方登陆的流程