木子CoCo~


私信TA

用户名:uq_78084890535

访问量:7788

签 名:

等  级
排  名 1147
经  验 3060
参赛次数 1
文章发表 24
年  龄 20
在职情况 学生
学  校 泰州学院
专  业 计算机科学与技术

  自我简介:

努力是奇迹的别名!

解题思路:
1.jpg

参考代码:

虽然这个代码可以ac但是如果输入相同数字超过10之后,会出现bug;

#include#includechar a[1000];
char b[105];
int n;
int main(){
	scanf("%s",&a);
	getchar();
	scanf("%d",&n);
	while(n--){
		int len=strlen(a);
		int i=0;
		//用b数组获取上一个数组元素 
		for( i=0;i<len;i++)
		b[i]=a[i];
		b[i+1]='\0';
		
		//经历一次变换后,更新a数组元素 
		int temp=0;
		for(int i=0;i<len;i++){
			//k表示 每个元素连续相等的个数 
		    int k=1;
			for(int j=i;j<len;j++){
				if(b[j]==b[j+1]){
					k++;
				}else{
					break;
				}
			}
			//记录一个元素个数  元素本身 
			a[temp]=k+'0';
			a[++temp]=b[i];
			 
			temp++;//位置++ 
			if(k!=1){
				i+=k-1;//如果某个元素有多个时,需要更新i的位置,(i的位置与k有关) 
			}
			
		}
		
	}
	puts(a);
	return 0;
}

补充:如果相同数字个数超过10之后,处理(此题不可能有超过100相同的数字)

if(k>=10){
				a[temp]=k/10+'0';
				a[++temp]=k%10+'0';
}

完善代码:

#include<stdio.h>
#include<string.h>
char a[1000];
char b[105];
int n;
int main(){
	scanf("%s",&a);
	getchar();
	scanf("%d",&n);
	while(n--){
		int len=strlen(a);
		int i=0;
		//用b数组获取上一个数组元素 
		for( i=0;i<len;i++)
		b[i]=a[i];
		b[i+1]='\0';
		
		//经历一次变换后,更新a数组元素 
		int temp=0;
		for(int i=0;i<len;i++){
			//k表示 每个元素连续相等的个数 
		    int k=1;
			for(int j=i;j<len;j++){
				if(b[j]==b[j+1]){
					k++;
				}else{
					break;
				}
			}
			//记录一个元素个数  元素本身 
			if(k>=10){
				a[temp]=k/10+'0';
				a[++temp]=k%10+'0';
			} else{
				a[temp]=k+'0';
			}
			a[++temp]=b[i];
			temp++;//位置++ 
			if(k!=1){
				i+=k-1;//如果某个元素有多个时,需要更新i的位置,(i的位置与k有关) 
			}
		}
		a[temp]='\0';
	}
	puts(a);
	return 0;
}


 

0.0分

3 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区

以上代码虽然可以ac,但是有bug;
考虑如果字符串1111111111112输入,结果错误
2020-08-19 07:18:48
  • «
  • 1
  • »