m0_73593365 2022-10-20 13:30 采纳率: 94%
浏览 20
已结题

为什么没有输出啊,给数组编号。

#include<stdio.h>
int main()
{
    int n,i,j,k,min,temp,x,y;
    int a[20],b[20];
    scanf("%d",&n);
    for(i=1; i<=n; i++)
    {
        scanf("%d",&a[i]);
        b[i]=a[i];
    }
    for(k=1; k<n; k++)
    {
        min=k;
        for(i=k+1; i<n+1; i++)
        {
            if(b[i]<b[min])
            {
                min=i;
            }
        }
        temp=b[min];
        b[min]=b[k];
        b[k]=temp;
    }
   
    printf("\n");
    for(x=1; x<=n; x++)
    {
        for(y=1; y<=n; y++)
        {
            while(b[x]==b[y])
        {
            for(i=1; i<n; i++)
                {
                    for(j=i+1; j<=n; j++)
                    {
                        if(b[i]==b[j])
                        {
                            for(k=j; k<=n; k++)
                            {
                                b[k]=b[k+1];
                            }
                        }
                        else
                        {
                            b[i]=b[i];
                        }
                    }
                }
            }
        }
    }
  


    
    for(i=1; i<=n; i++)
    {
        for(j=1; j<=n; j++)
        {
            if(a[i]==b[j])
            {
                printf("%d ",j);
            }
        }
    }


    return 0;
}

没有输出,怎么办啊

img

  • 写回答

1条回答 默认 最新

  • 浪客 2022-10-20 14:03
    关注
    
     
    #include <stdio.h>
    int main()
    {
        int n, i, j, k, min, temp, cnt = 0;
        int a[20][2], b[20] ; //a[][0]存数据,a[][1]存排序号
        scanf("%d", &n);
        for (i = 0; i < n; i++) //
        {
            scanf("%d", &a[i][0]);
            a[i][1] = 0;
     
            for (j = 0; j < i; j++) //b只保存不重复项
            {
                if (b[j] == a[i][0])
                    break;
            }
            if (j == i)
            {
                b[cnt] = a[i][0];
                cnt++; //不同项数量
            }
        }
        // b排序
        for (k = 0; k < cnt - 1; k++)
        {
            for (i = k + 1; i < cnt; i++)
            {
                if (b[i] < b[k])
                {
                    temp = b[i];
                    b[i] = b[k];
                    b[k] = temp;
                }
            }
        }
        //从a中按b的顺序查找并赋值顺序号
        for (i = 0; i < cnt; i++)
        {
            for (j = 0; j < n; j++)
            {
                if (a[j][0] == b[i])
                {
                    a[j][1] = i + 1;
                }
            }
        }
        for (i = 0; i < n; i++)
        {
            printf("%d ", a[i][1]);
        }
     
        return 0;
    }
     
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月28日
  • 已采纳回答 10月20日
  • 创建了问题 10月20日

悬赏问题

  • ¥15 BP神经网络控制倒立摆
  • ¥20 要这个数学建模编程的代码 并且能完整允许出来结果 完整的过程和数据的结果
  • ¥15 html5+css和javascript有人可以帮吗?图片要怎么插入代码里面啊
  • ¥30 Unity接入微信SDK 无法开启摄像头
  • ¥20 有偿 写代码 要用特定的软件anaconda 里的jvpyter 用python3写
  • ¥20 cad图纸,chx-3六轴码垛机器人
  • ¥15 移动摄像头专网需要解vlan
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算