(PAT乙级) 1084 外观数列 (C语言实现,不要使用strcat)

news/2024/7/24 13:16:33 标签: c语言, 算法

外观数列是指具有以下特点的整数序列:

d, d1, d111, d113, d11231, d112213111, ...

它从不等于 1 的数字 d 开始,序列的第 n+1 项是对第 n 项的描述。比如第 2 项表示第 1 项有 1 个 d,所以就是 d1;第 2 项是 1 个 d(对应 d1)和 1 个 1(对应 11),所以第 3 项就是 d111。又比如第 4 项是 d113,其描述就是 1 个 d,2 个 1,1 个 3,所以下一项就是 d11231。当然这个定义对 d = 1 也成立。本题要求你推算任意给定数字 d 的外观数列的第 N 项。

输入格式:

输入第一行给出 [0,9] 范围内的一个整数 d、以及一个正整数 N(≤ 40),用空格分隔。

输出格式:

在一行中给出数字 d 的外观数列的第 N 项。

输入样例:

1 8

输出样例:

1123123111
题目分析:

本题和 PTA 1078压缩字符串一题比较类似https://pintia.cn/problem-sets/994805260223102976/exam/problems/994805262018265088

不过需要注意的是 strcat的效率问题,strcat在追加字符上细性能比较差,本题如果使用strcat实现 +=字符的效果会出现运行超时的情况

而且,本题的结果会比较长,建议使用100000以上的数组空间!

如何优化strcat?

这里我的做法是使用index索引代替,使用index索引时间上能缩小非常大的时间。下图中如果使用strcat会超过400ms,使用索引之后反而只需要4ms

image-20240322153020918

#include <ctype.h>
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

void reverse_str(char *str){
	int left=0,right=strlen(str)-1;
	char ch;
	while(left<right){
		ch=str[left];
		str[left]=str[right];
		str[right]=ch;
		left++;
		right--;	
	}
}

char* to_string(int num){
	char* str=calloc(500,sizeof(char));
	memset(str,'\0',sizeof(str));
	int index=0;
	while(num!=0){
		str[index++]=(num%10)+'0';
		num/=10;
	}
	reverse_str(str);
	return str;
}

char* getnext(char *str){
	int num[500];
	char *nstr=calloc(100000,sizeof(char));
	memset(num,0,sizeof(num));
	int i,j,index=0;
	num[str[0]]++;
	for(i=1;str[i]!='\0';i++){
		if(str[i]!=str[i-1]){
			nstr[index++]=str[i-1];
			nstr[index++]=num[str[i-1]]+'0';
//			strcat(nstr,ch);
			num[str[i-1]]=0;
		}
		num[str[i]]++;
	}
	
	int end=strlen(str)-1;
	nstr[index++]=str[end];
	nstr[index++]=num[str[end]]+'0';
//	strcat(nstr,ch);
	return nstr;
}

int main() {
  int d,n,i;
  char str[100000]="";
  scanf("%d %d",&d,&n);
  str[0]=d+'0';
  
  char *next,*cur=str;
  for(i=2;i<=n;i++){
  	next=getnext(cur);
  	cur=next;
//  	printf("%s\n",str);
  }
  printf("%s\n",cur);
  return 0;
}


http://www.niftyadmin.cn/n/5455963.html

相关文章

Linux - 第五节

sudo用不了 - 新建的普通用户 以管理员的身份&#xff0c;去修改etc/sudoers配置下的文件&#xff0c;添加白名单 代码的编译 gcc - 只能用于编译C语言 g - 既能用来编译C语言&#xff0c;也能用来编译C ggc的简易用法 预处理 预处理功能主要包括宏定义,文件包含,条件编…

HarmonyOS(鸿蒙开发)入门篇

如果需要学习鸿蒙开发可以查看以下学习资源链接 OpenAtom OpenHarmony Develop applications - HUAWEI HarmonyOS APP 转载请注明出处HarmonyOS(鸿蒙开发&#xff09;入门篇-CSDN博客&#xff0c;谢谢&#xff01;

InputStream字节输入流和OutStream字节输出流

InputStream InputStream是Java标准库最基本的输入流&#xff0c;在java.io包内。它是一个抽象类。 FileInputStream&#xff1a;从文件中读取数据&#xff0c;是最终数据源。 int read()方法&#xff1a;读取输入流的下一个字节&#xff0c;并返回字节表示的int值&#xff08;…

酒店智能水电表管理解决方案:提升效率、节约成本与环保并重

随着科技的不断发展&#xff0c;智能水电表管理解决方案在酒店行业中得到了广泛应用。这一解决方案结合了物联网技术和智能管理系统&#xff0c;旨在提升酒店水电资源利用效率&#xff0c;降低运营成本&#xff0c;同时也致力于环保与可持续发展。本文将从多个方面介绍酒店智能…

广义表的深度与长度

1.广义表的长度和深度 1.长度&#xff1a;广义表的长度是指广义表中第一层所含的元素个数&#xff0c;包括原子和子表。 理解&#xff1a;广义表的长的也就是最外层的括号中包含的元素的个数 2.深度&#xff1a;广义表的深度是指广义表中括号的最大层数&#xff0c;即最大嵌套…

蓝桥杯(3):python搜索DFS

目录 1 DFS简介 1.1 DFS与n重循环 1.2 代码实现 1.3 例题 1.3.1 分糖果 1.3.2 买瓜 2 回溯 2.1 定义 2.2 代码实例 2.1.1 排列数 2.1.2 找子集 2.3 例题 2.3.1 N皇后 2.3.2 小朋友崇拜圈 2.3.3 全球变暖 3 剪枝 3.1 定义 3.2 分类 3.3 例子 3.3.1 数字王国之…

SQL:窗口函数之OVER()

窗口函数 通用格式 “函数 OVER (PARTITION BY 分组 ORDER BY 排序依据 升降序)”。 这里记录下OVER() 以及搭配LEAD/LAG函数的使用方法&#xff08;执行平台Impala&#xff09; 目录 OVER函数1、不加条件的OVER函数——得到所有的汇总结果2、仅有排序的OVER函数——得到按顺序…

景联文科技高质量大模型训练数据汇总!

3月25日&#xff0c;2024年中国发展高层论坛年会上&#xff0c;国家数据局局长刘烈宏在“释放数据要素价值&#xff0c;助力可持续发展”的演讲中表示&#xff0c;中国10亿参数规模以上的大模型数量已超100个。 当前&#xff0c;国内AI大模型发展仍面临诸多困境。其中&#xff…