oj 1.9编程基础之顺序查找 09:直方图
给定一个非负整数数组,统计里面每一个数的出现次数。我们只统计到数组里最大的数。
假设 Fmax (Fmax < 10000)是数组里最大的数,那么我们只统计 {0,1,2.....Fmax} 里每个数出现的次数。
输入
第一行n是数组的大小。1 <= n <= 10000。
紧接着一行是数组的n个元素。
输出
按顺序输出每个数的出现次数,一行一个数。如果没有出现过,则输出0。
对于例子中的数组,最大的数是3,因此我们只统计{0,1,2,3}的出现频数。
样例输入
5 1 1 2 3 1
样例输出
0 3 1 1
#include<stdio.h>
#include<string.h>
void querry(int arr[],int len)
{
int i,j;
for(i=0;i<len;i++)
{
for(j=0;j<len-1-i;j++)
{
if(arr[j]>arr[j+1])
{
int temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
}
int main()
{
int n;
int i;
scanf("%d",&n);
int arr[10000];
for(i=0;i<n;i++)
{
scanf("%d",&arr[i]);
}
querry(arr,n);
/* for(i=0;i<n;i++)
{
printf("%d ",arr[i]);
}
printf("\n");
*/
i=0;
/*
这是统计数组中出现数的次数(除了0)
while(i<n)
{
if(arr[i]>=0)
{
while(arr[i]==arr[i+1])
{
count++;
i++;
}//循环判断是否相等(防止值考虑到2次相等的情况)
printf("%d\n",count);
count=1;
}
i++;//这个i++应该是在判断之外
}
*/
int count[10000];
memset(count,0,(arr[n-1]+1)*sizeof(int));//这里也要记得加1
for(i=0;i<n;i++)
{
count[arr[i]]++;
}
for(i=0;i<arr[n-1]+1;i++)//这里要记得+1
{
printf("%d\n",count[i]);
}
return 0;
}