你题目的解答代码如下:
#include <stdio.h>
int main()
{
int n,m,i,g=0,j=0;
int a[101] = {0};
scanf("%d", &n);
int b[n];
for (i = 0; i < n; i++)
{
scanf("%d", &m);
if (a[m]==0)
b[j++] = m;
a[m]++;
}
for (i = 0; i < j; i++)
if (a[b[i]]>1)
{
printf("%d ", b[i]);
g++;
}
if (g==0)
printf("Not Found");
return 0;
}
如有帮助,望采纳!谢谢!
遍历数组,每次输入新数据时判断已经输入的数据中是否已经存在该数字了,代码如下:
#include <stdio.h>
#include <stdlib.h>
int main()
{
int i,j,*p,*q,n,k,nmb=0;
int flag = 0;
scanf("%d",&n);
p = (int*)malloc(sizeof(int)*n);
q = (int*)malloc(sizeof(int)*n); //记录出现的次数
for(i=0;i<n;i++)
q[i] = 0;
for(i=0;i<n;i++)
{
scanf("%d",&k);
//判断是否已经出现过
for(j=0;j<nmb;j++)
{
if(p[j] == k)
break;
}
if(j<nmb)//说明出现过
{
q[j]++;
}else
{
q[nmb] = 1;
p[nmb] = k;
nmb++;
}
}
if(nmb == 0)
{
printf("Not Found");
free(p);p = 0;
free(q);q=0;
return 0;
}
for(j=0;j<nmb;j++)
{
if(q[j]>1)
{
if(flag ==0)
{
printf("%d",p[j]);
flag = 1;
}
else
printf(" %d",p[j]);
}
}
free(p);p = 0;
free(q);q=0;
return 0;
}