给定一个非空字符串S,其被N个‘-’分隔成N+1的子串,给定正整数K,要求除第一个子串外,其余的子串每K个字符组成新的子串,并用‘-’分隔。对于新组成的每一个子串,如果它含有的小写字母比大写字母多,则将这个子串的所有大写字母转换为小写字母;反之,如果它含有的大写字母比小写字母多,则将这个子串的所有小写字母转换为大写字母;大小写字母的数量相等时,不做转换。
输入描述:
输入为两行,第一行为参数K,第二行为字符串S。
输出描述:
输出转换后的字符串。
示例1
输入
3
12abc-abCABc-4aB@
输出
12abc-abc-ABC-4aB-@
说明
子串为12abc、abCABc、4aB@,第一个子串保留,后面的子串每3个字符一组为abC、ABc、4aB、@,abC中小写字母较多,转换为abc,ABc中大写字母较多,转换为ABC,4aB中大小写字母都为1个,不做转换,@中没有字母,连起来即12abc-abc-ABC-4aB-@
示例2
输入
12
12abc-abCABc-4aB@
输出
12abc-abCABc4aB@
说明
子串为12abc、abCABc、4aB@,第一个子串保留,后面的子串每12个字符一组为abCABc4aB@,这个子串中大小写字母都为4个,不做转换,连起来即12abc-abCABc4aB@作者:yaozi
链接:https://leetcode.cn/circle/discuss/niKSMZ/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
一、问题分析
首先读题,仔细看描述中的内容,发现需求是
1.先接受一个正整数K,再接受一个字符串
2.字符串第一个‘-’之前的内容不变
3.之后的内容,每K个为一组,
4.统计组内大小写字母数量,如果大写字母多,将所有小写字母都转成大写
5.如果小写字母多,则将所有大写字母都转成小写
6.如果一样多,保持不变
7.每组字符用'-'隔开。
二、解题思路
1.引入标准输入输出库,字符串处理库,字符处理库
#include <stdio.h>
#include <string.h>
#include <ctype.h>
2.在主程序中
int main()
3.首先定义一个整数变量int K;
4.然后定义一个字符数组char input[100];
5.然后接受一个整数scanf("%d", K);
6.接受字符串fgets(input, sizeof(input), stdin);
7.对字符串进行处理将多余的换行符变成字符串结束符号
input[strchr(input,'\n')] = '\0';
8.查找第一个‘-’的位置
char* first = strchr(input,'-');
9.如果没有找到,那么我们直接输出input,就是我们的结果了
if(first == NULL) {
printf("%s\n", input);
return 0;
}
10.如果找到了,那么我们输出从开始到第一个‘-’的内容
else {
char tmp[100];
strncpy(tmp, input, first - input);
printf("%s", tmp);
然后将input的内容截去第一个-之前的内容
strncpy(input, first, strlen(input) - (first - input));
}
11.我们遍历input然后将所有的‘-’去掉(新建一个字符串)
char in[100];
int len = 0;
for(int i = 0; i < strlen(input); i++) {
if(input[i] != '-') in[len++] = input[i];
}
12.我们遍历字符串in,将其分隔成K个一组,用‘-’隔开的字符串
for(int i = 0; i < len; i += K){
int up = 0;
int low = 0;
for(int j = 0; j < K && i + j < len; j++) {
if(isupper(in[i + j])) up++;
else if(islower(in[i + j])) low++;
}
if(up > low) {
for(int j = 0; j < K && i + j < len; j++){
putchar(toupper(in[i + j]));
} else if (low > up) {
for(int j = 0; j < K && i + j < len; j++){
putchar(tolower(in[i + j]));
} else {
for(int j = 0; j < K && i + j < len; j++){
putchar(in[i + j]);
}
if(i + K < len) putchar('-');
}
}
三、具体步骤
使用的语言是C
#include <stdio.h>
#include <string.h>
#include <ctype.h>
int main() {
int K;
// 检查 scanf 的返回值以确保正确读取整数 K
if (scanf("%d", &K)!= 1) {
printf("输入错误,请输入一个整数。\n");
return 1;
}
char input[100];
if (fgets(input, sizeof(input), stdin) == NULL) {
printf("输入错误,请输入一个字符串。\n");
return 1;
}
input[strcspn(input, "\n")] = '\0';
char* first = strchr(input,'-');
if (first == NULL) {
printf("%s\n", input);
return 0;
} else {
char tmp[100];
strncpy(tmp, input, first - input + 1);
printf("%s", tmp);
strncpy(input, first, strlen(input) - (first - input) + 1);
}
char in[100];
int len = 0;
for (int i = 0; i < strlen(input); i++) {
if (input[i]!= '-') {
in[len++] = input[i];
}
}
for (int i = 0; i < len; i += K) {
int up = 0;
int low = 0;
for (int j = 0; j < K && i + j < len; j++) {
if (isupper(in[i + j])) {
up++;
} else if (islower(in[i + j])) {
low++;
}
}
if (up > low) {
for (int j = 0; j < K && i + j < len; j++) {
putchar(toupper(in[i + j]));
}
} else if (low > up) {
for (int j = 0; j < K && i + j < len; j++) {
putchar(tolower(in[i + j]));
}
} else {
for (int j = 0; j < K && i + j < len; j++) {
putchar(in[i + j]);
}
}
if (i + K < len) {
putchar('-');
}
}
return 0;
}