请问各位这种情况怎么做

img

你题目的解答代码如下:

#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;
}

img

如有帮助,望采纳!谢谢!

遍历数组,每次输入新数据时判断已经输入的数据中是否已经存在该数字了,代码如下:

#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;
}