字符串删减(蓝桥杯每日一题)
字符串删减(蓝桥杯每日一题)
字符串删减给定一个由 n个小写字母构成的字符串。现在,需要删掉其中的一些字母,使得字符串中不存在连续三个或三个以上的 x。请问,最少需要删掉多少个字母?如果字符串本来就不存在连续的三个或三个以上 x,则无需删掉任何字母。输入格式
第一行包含整数 n。第二行包含一个长度为 n的由小写字母构成的字符串。输出格式输出最少需要删掉的字母个数。数据范围
≤n≤100
输
字符串删减(蓝桥杯每日一题)
给定一个由 n个小写字母构成的字符串。
现在,需要删掉其中的一些字母,使得字符串中不存在连续三个或三个以上的 x。
请问,最少需要删掉多少个字母?
如果字符串本来就不存在连续的三个或三个以上 x,则无需删掉任何字母。
输入格式 第一行包含整数 n。
第二行包含一个长度为 n的由小写字母构成的字符串。
输出格式
输出最少需要删掉的字母个数。
数据范围 ≤n≤100 输入样例1: 6 xxxiii 输出样例1: 1 输入样例2: 5 xxoxx 输出样例2: 0 输入样例: 10 xxxxxxxxxx 输出样例: 8
算法思路
首先是定义一个变量cnt记录当前连续出现的字符的x的个数; 每出现一个字符x,cnt加一; 所出现一个其他的字符,则cnt直接清零; 当cnt=,表示连续出现了个x,这个时候就需要清除一次cnt,让cnt–,然后继续遍历。
C++
代码语言:javascript代码运行次数:0运行复制#include<bits/stdc++.h>
using namespace std;
int main()
{
int n;
string s;
cin >> n >> s;
int res = 0, cnt = 0;
for (int i = 0; i < n; ++ i)
{
if (s[i] == 'x')
{
cnt ++;
if (cnt == )
{
res ++;
cnt --;
}
}
else
{
cnt = 0;
}
}
cout << res << endl;
return 0;
}
Java
代码语言:javascript代码运行次数:0运行复制import java.util.*;
public class Main
{
public static void main(String[] args)
{
int n;
String s;
Scanner in = new Scanner(System.in);
n = ();
s = ();
char [] chars = ();
int res = 0, cnt = 0;
for (int i = 0; i < n; ++ i)
{
if (chars[i] == 'x')
{
cnt ++;
if (cnt == )
{
res ++;
cnt --;
}
}
else
{
cnt = 0;
}
}
println(res);
}
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。 原始发表:2025-01-20,如有侵权请联系 cloudcommunity@tencent 删除遍历变量数据算法字符串 #感谢您对电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格的认可,转载请说明来源于"电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格
上传时间: 2025-07-19 11:31:45
推荐阅读
留言与评论(共有 8 条评论) |
本站网友 生态双眼皮 | 18分钟前 发表 |
字符串删减(蓝桥杯每日一题) 字符串删减给定一个由 n个小写字母构成的字符串 | |
本站网友 上海私房出租 | 7分钟前 发表 |
现在 | |
本站网友 长沙万科城 | 11分钟前 发表 |
让cnt– | |
本站网友 北京新世界百货官网 | 15分钟前 发表 |
cnt = 0; for (int i = 0; i < n; ++ i) { if (chars[i] == 'x') { cnt ++; if (cnt == ) { res ++; cnt --; } } else { cnt = 0; } } println(res); } }本文参与 腾讯云自媒体同步曝光计划 | |
本站网友 苏州园区租房 | 28分钟前 发表 |
cnt = 0; for (int i = 0; i < n; ++ i) { if (s[i] == 'x') { cnt ++; if (cnt == ) { res ++; cnt --; } } else { cnt = 0; } } cout << res << endl; return 0; }Java代码语言:javascript代码运行次数:0运行复制import java.util.*; public class Main { public static void main(String[] args) { int n; String s; Scanner in = new Scanner(System.in); n = (); s = (); char [] chars = (); int res = 0 | |
本站网友 黄德坤 | 15分钟前 发表 |
需要删掉其中的一些字母 | |
本站网友 阅城国际花园 | 12分钟前 发表 |
请问 |