shu_xiao1 2021-11-28 13:04 采纳率: 100%
浏览 22
已结题

数组输出不重复的排序序号

题目:
数组:{23 22 34 56 23 78 69 31 34 56},得到的数组的排序序号为:{8 10 5 3 8 1 2 7 5 3}。如何得到数组排序序号为{8 10 5 3 9 1 2 7 6 4}?

目前可以输出第一个由重复序号的结果

int i,j,t;
printf("请输入10个数字:\n");
for(i=0;i<10;i++)
    scanf("%d",&a[i]);
for(i=0;i<10;i++)
{
    for(j=0,t=0;j<10;j++)
    {if(a[j]>a[i])t++;
      b[i]=t+1;}
}
for(i=0;i<10;i++)
printf("%d ",b[i]);
printf("\n");
  • 写回答

1条回答 默认 最新

  • 校歪歪 2021-11-28 13:53
    关注

    如果不修改程序结构的话,按原思路可以再加一个循环来判断之前是否有重复值,插入位置紧接着原语句b[i]=t+1 的后面

    for(int x=0;x<i;x++)
    {
        if(b[x]==b[i])b[i]+=1;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 12月6日
  • 已采纳回答 11月28日
  • 创建了问题 11月28日