其他分享
首页 > 其他分享> > 师大月赛的字符串整理

师大月赛的字符串整理

作者:互联网

字符串!!!

没错。。。
这篇博客只有字符串(知识盲区呜呜呜傻傻分不清)。
最近几次做题有字符串就必跪,所以希望通过这篇博客再提升自己一下!
先来一道666的题

一.

题目描述

zhb开办的太极门过于火爆,聪明的zhb发现只考核混元功法已经不足以满足学生毕业的需要,于是他想出来了一个新的考核办法。每一个考试的学生zhb会给出一个句子,学生需要将里面出现的6进行替换。但它可不是乱替换的, 只有当出现超过3 个连续的 6时,需要替换为"9";但如果有超过 9 个连续的 6,则将这串连续的 6 替换成"hun yuan zhb"。
下面请你帮助zhb完成考核
输入

输入在一行中给出一句话,即一个非空字符串,由不超过 1000个标点符号、英文字母、数字和空格组成,以回车结束。

输出

从左到右扫描输入的句子:如果句子中有超过 3 个连续的 6,则将这串连续的 6 替换成 9;但如果有超过 9 个连续的 6,则将这串连续的 6 替换成"hun yuan zhb"。其他内容不受影响,原样输出。

样例输入

it is so 666 really 6666 what else can I say 6666666666
样例输出

it is so 666 really 9 what else can I say hun yuan zhb

经过hz大佬的一番点拨,本蒻蒟整理出了自己的一点思路,但是还是有一点模糊,希望评论区的大佬也能给出一些建议(跪了)。

在输入字符串时没有用scanf,而是用了gets,原因是scanf可能会吞空格回车等情况,当然也可以用scanf搭配getchar来吃掉空格和回车,输入字符串之后,我们首先一个一个判断如果不是6,那我们就直接输出,如果是6,我们对他连续的出现次数进行计数,如果满足条件就输出对应的目标语句,否则就输出原句,大体思路就是这样。
上代码

#include <stdio.h>
#include <string.h>
char a[1010];
int main(){
   gets(a);//输入我们的字符串
    int x=0;
    for(int i=0;i<strlen(a);i++){
        if(a[i]=='6'){
            x++;//如果这个元素为6那我们就为他计数
            if(i==strlen(a)-1){
                if(x>9) printf("hun yuan zhb");
                if(x>3&&x<=9) printf("9");
                if(x>0&&x<=3) while(x--) printf("6");
            }
        }
        else{
            if(x>9) printf("hun yuan zhb");//在句子中一旦碰到非6字符开始判断6的个数>9输出目标
            if(x>3&&x<=9) printf("9");
            if(x>0&&x<=3) while(x--) printf("6");//若小于3则输出6;
            x=0;
            printf("%c",a[i]);//若不为6则输出这个元素;
        }
    }
    printf("\n");
    return 0;
}

二.

题目描述

众所周知,zhb的英语非常非常差,甚至一看见英文单词就头痛,zhb的英语老师给他留了一项作业,想让他求出一个字符串中最长的连续出现的字符,以及它出现的次数,如果这样的字符不止一个,则输出第一个。zhb的英语马上就要挂科了,你能帮他完成这项任务吗?

输入

第一行一个整数N,表示测试数据的组数。
每组数据占一行,包含一个不含空白字符的字符串,字符串长度不超过200。

输出

共一行,输出最长的连续出现的字符机器出现次数,中间用空格隔开。

样例输入
2
aaaaabbbbbcccccccdddddddddd
abcdefghigk

样例输出
d 10
a 1

这道题首先要定义几个变量来存放连续出现最多的次数和对应的字符,所以在其中我们在出现次数大于已有最大值时,将最大值和字符都进行替换,并同时进行累加,直到遍历到数组的最后一个元素时输出最大值与对应的元素。

#include <stdio.h>
#include <string.h>
char a[210];
int main(){
   int n,s=1,max=1;
   scanf("%d",&n);
   getchar();
   while(n--){
	   scanf("%s",a);
	   getchar();
	   int i;char op=a[0];
	   for(i=0;i<strlen(a);i++){
		   if(s>max){
			   max=s;
			   op=a[i];

		   }
		   if(a[i]==a[i+1])
			   s++;
		   else
			   if(a[i]!=a[i+1])
			   {
				   s=1;
			   }

	   }
	   
	   printf("%c %d\n",op,max);
	   max=1;
   }
   return 0;
}

这里有一个小问题,在输入字符串时,我开始使用的时gets,但是发现一直WA,后来将其替换成scanf+getchar ()之后就ac了,对这个地方我还有一些疑问,希望大家指导。

标签:月赛,输出,int,scanf,zhb,字符串,师大,输入
来源: https://blog.csdn.net/lucifer1214/article/details/111026323