咖啡


私信TA

用户名:Tianxn

访问量:129166

签 名:

十年OI一场空,不开LL见祖宗。

等  级
排  名 9
经  验 26197
参赛次数 10
文章发表 197
年  龄 22
在职情况 学生
学  校 西安电子科技大学
专  业 软件工程

  自我简介:

解题思路:

                    我们可以定义一个b[1000001]并全部置0(直接等于0就行了或者用<string.h>头文件下的memset(b,0,sizeof(b)));用来存储每一个数出现的次数,比如输入了一个 6,就执行b[6]++;接着输入 123,就执行b[123]++;再输入6,执行b[6]++; 到目前为止,b数组存的是对应下标数字出现的次数,那么输入完,只用判断b数组元素不为0的就打印; 这里我们不用考虑顺序,其实输出就是有序输出的, 我们刚说,数组下标就是对应输入的数字,数组下标肯定是有序的(从小到大),下标对应位置存储的就是,和数组下标相同的数字的个数。


                还有不懂得可以留言,我最近三个月内,每天都在。

注意事项:

                    定义数组时,放在main()外面;因为数组太大,会导致栈溢出的。

参考代码:

#include <stdio.h>
int n, a[1001]={0},b[1000001]={0};
int main()
{
	scanf("%d", &n);
	for(int i = 0; i < n; ++i)
	{
		scanf("%d", &a[i]);
		b[a[i]]++;
	}
	for(int i = 0; i < 1000001; ++i)
	{
		if(b[i] != 0)
		{
			printf("%d %d\n", i, b[i]);
		}
	}
    return 0;
}


 

0.0分

3 人评分

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

编程语言转换万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区

#include<stdio.h>
#include <string.h>
int main()
{   
	int n,i,max=0;
	long long x, a[1000], book[1000000] = {0};
	scanf("%d", &n);
	for (i = 0; i < n; i++) {
		scanf("%d", &a[i]);
		if (a[i] > max)
			max = a[i];
	}
	for (i = 0; i < n; i++) {
		book[a[i]]++;
	}
	for (i = 0; i <= max; i++) {
		if (book[i] != 0)
			printf("%d %lld\n", i, book[i]);
	}
	return 0;
}
获取 最大的元素max 可以减少标记数组book的循环次数
2022-09-22 17:00:23
关注下大神
2018-11-02 22:04:55
  • «
  • 1
  • »