字符串问题之 去掉字符串中连续出现K个0的子串
字符串中刚好出现K个连续的‘O’,则把K个连续‘O’字符去除,返回处理后的字符串
比如 str="AOOOOOBOOO" k=3, 返回“AOOOOOB”
这个题的解决思路也有很多
重要的是,关键的是,如何从左到右便利str时,将正好有连续的K个‘0’字符串都找到
解题思路步骤
1 生成两个变量。 int count 表示目前连续个‘O’的数量, 整型变量start,表示连续个‘O’出现的初始位置
2 从左到右 遍历str, 根据此处的内容cha做不同处理
3 如果cha是‘O’ 然后看看 star = star==-1?i:start
4 如果char不是‘O’ 这是去掉'O'的时刻,要查看 count 等于 K不!是则删,不是则不删,最后令count=0 start=-1
5 去‘O’的时刻是 不是‘O’的时候如果是以‘O’ 结尾的呢?! 考虑周全!需要判断 count是不是为K
废话不多说,代码贴上
package TT; public class Test3 { public static String removeKZeros(String str, int k){ if(str==null || k<1){
return str;
} char[] chas = str.toCharArray();
int count = 0, start =-1; for(int i=0; i!=chas.length; i++){
if(chas[i] =='O'){
count++;
start = start==-1 ? i : start; }else {
if(count == k){
while(count-- !=0){
chas[start++]=0;
}
}
count = 0;
start = -1;
}
} if(count == k){
while(count-- !=0){
chas[start++]=0;
}
}
return String.valueOf(chas);
} public static void main(String[] args){ String str = "AOOOOOBOOO";
int k = 3;
String str1= removeKZeros(str,k);
System.out.println(str1); } }
重点在这里:
public class Test5 { public static void main(String[] args) {
char[] x = {'A',0,0,0,'B'};
String xString = String.valueOf(x);
System.out.println(xString);
System.out.println(xString.charAt(1)==0);
} }
结果:
我又想了个递归版:
public class Test2 {
public static String getRemoveRetain(String str,int k) {
if (k<=0) {
return "不要乱搞";
}
String S ="";
String strTest = str;
for (int i = 0; i < k; i++) {
S+="O";
} int record = str.indexOf(S);
if (record == -1) {
return str;
}
else if ((record+k)>=str.length()) {
return str.substring(0,record);
}
else if ((str.charAt(record+k)=='O') || (str.charAt(record+k)=='O')) {
int j = record+k;
while (str.charAt(j) == 'O') {
j++;
}
return str.substring(0,j).concat(getRemoveRetain(str.substring(j), k));
}else if (str.charAt(record+k) !='O') {
String substring = str.substring(record+k);
return str.substring(0,record).concat(getRemoveRetain(substring, k));
}
return str;
} public static void main(String[] args) {
String s ="AOOOOOBOOOBOOO";
System.out.println(getRemoveRetain(s, 3));
}
}
写法有太多了:
public class t4 { public static String removeKo(String str, int k) {
if (str == null || k < 1) {
return str;
}
char[] chars = str.toCharArray();
int count = 0;
for (int i = 0 ; i< chars.length; i++){
if (chars[i] == '0'){
count++;
}
if(chars[i] != '0' && count == k){
int index = k;
int j = i-1;
while (index!=0 && ((i-1)>=0)){
chars[j] = 0;
index--;
j--;
}
//计算完毕要清空count
count=0;
}
if (chars[i] !='0' && count != k){
count=0;
}
}
//遍历完毕最后的判断
if (count == k){
int index = chars.length-1;
int sub = k;
//临界值为0时候已经不可以了 可以假设k为1的情况 预设
while (sub >0){
chars[index--]=0;
sub--;
}
}
return String.valueOf(chars);
}
public static void main(String[] args){
String str="A000B000";
String s = removeKo(str, 3);
System.out.println(s); }
}
字符串问题之 去掉字符串中连续出现K个0的子串的更多相关文章
- 《程序员代码面试指南》第五章 字符串问题 去掉字符串中连续出现k 个0 的子串
题目 去掉字符串中连续出现k 个0 的子串 java代码 package com.lizhouwei.chapter5; /** * @Description: 去掉字符串中连续出现k 个0 的子串 ...
- 字符串问题----去掉字符串中连续出现K个0的子串
去掉字符串中连续出现K个0的子串 给定一个字符串str,和一个整数k, 如果str中正好有连续K 个'0'字符出现,把连续的 k 个 '0'去掉,返回处理后的子串. [解题思路] 1. 定义两个变量, ...
- 字符串问题:去掉字符串中连续出现 k 个 0 的子串
[题目] 给定一个字符串 str 和 一个整数 k, 如果 str 中正好有连续 k 个 ‘0’ 字符出现时,把 k 个连续的 ‘0’ 字符去除,返回处理后的字符串. [举例] str="A ...
- 给定一个字符串str,将str中连续两个字符为a的字符替换为b(一个或连续超过多个字符a则不替换)
需求:给定一个字符串str,将str中连续两个字符为a的字符替换为b(一个或连续超过多个字符a则不替换) 如: a 不替换 b 不替换 ab 不替换 ba 不替换 aba 不替换 aab 替换为 ...
- [算法]去掉字符串中连续出现的k个0子串
题目: 给定一个字符串str和一个整数k,如果str中正好有k个‘0’字符出现时,把k个连续的‘0’字符去除,返回处理后的字符串. 举例: str=”A00B”,k=2,返回“AB” str=”A00 ...
- String的trim()用于去掉字符串前后的空格
String的trim()可以去掉字符串的前导和后继字符串,即去掉字符串前面和后面的空格. eg:String userName = " good man "; System.ou ...
- 【PHP函数】PHP 去掉字符串中的转义符号
PHP字符串中的转义符号 string stripslashes ( string $str ) //去掉字符串中的反斜线字符.若是连续二个反斜线,则去掉一个,留下一个.若只有一个反斜线,就直接去掉.
- C++去掉字符串中首尾空格和所有空格
c++去掉首尾空格是参考一篇文章的,但是忘记文章出处了,就略过吧. 去掉首尾空格的代码如下: void trim(string &s) { if( !s.empty() ) { s.erase ...
- C# 使用正则表达式去掉字符串中的数字,或者去掉字符串中的非数字
/// 去掉字符串中的数字 public static string RemoveNumber(string key) { ...
随机推荐
- spring-security+hibernate4+quartz实现的心跳检测项目(转 收藏)
转自:http://www.52itstyle.com/thread-27470-1-1.html HeartBeat. ~2 Z8 U! ?8 r心跳检测各类应用服务器(如Tomcat,Jetty) ...
- 三、docker官网注册docker id
docker官网注册docker ID 电脑注册docker没有成功,网上有人说用手机注册,试了一下确实可以注册. 1.下载蓝灯软件开启FQ代理. 2.登录网站,按照提示注册.
- NPOI操作Excel常用函数
最近因项目接触了NPOI,感觉还是蛮不错的,网络上的教程普遍版本较老,本篇记录所常用操作,采用NPOI 2.0版本. 推荐: NPOI官方网站 NPOI 1.2.4/1.2.5 官方教程 新建Exce ...
- 巨蟒python全栈开发linux之centos4
1.linux虚拟环境1-4 2.linux运行crm代码
- JS和C# 里的闭包及闭包在事件中的使用
在Javascript世界里,无所不用闭包及自定义事件, 自定义事件其实也是事先定义好一种规则 ,当触发者被响应后执行的一段回调.下面看个例子 function dothing(callBack){ ...
- SQLServer中exists和except用法
一.exists 1.1 说明 EXISTS(包括 NOT EXISTS)子句的返回值是一个BOOL值.EXISTS内部有一个子查询语句(SELECT ... FROM...),我将其称为EXIST的 ...
- Facebook背后的软件
Facebook的数据规模使得很多传统的解决方案根本不适用,或者无法分解来处理.保持一个拥有5亿用户的系统一直稳定可靠的运行,并不是一件很容易的事情.这篇文章介绍了一下Facebook使用的软件. F ...
- element-UI的操作步骤steps每一项添加事件,比如click,hover
简单来说,只添加click 和css :hover就好了 一.组件里 <el-steps :space="200" :active="1" finish- ...
- ThreadPoolExecutor 线程池任务队列分析 与 利特尔法则(Little's law)
一. 演示 public class ThreadPoolTest { static class MyThread implements Runnable { private String name; ...
- 001-OSI七层模型,TCP/IP五层模型
一.概述 OSI(Open System Interconnection)参考模型是国际标准化组织(ISO)制定的一个用于计算机或通信系统间互联的标准体系,一般称为OSI参考模型或七层模型. OSI/ ...