排序问题(正解

    xiaoxiao2021-03-25  153

    题目描述

    输入10个整数,将它们从小到大排序后输出,并给出现在每个元素在原来序列中的位置。

    输入

    输入数据有一行,包含10个整数,用空格分开。

    输出

    输出数据有两行,第一行为排序后的序列,第二行为排序后各个元素在原来序列中的位置。

    样例输入

    1 2 3 5 4 6 8 9 10 7

    样例输出

    1 2 3 4 5 6 7 8 9 10 1 2 3 5 4 6 10 7 8 9

    提示

       #include <stdio.h> #include <stdlib.h> int main() { int i,j=0,a[10],b[10]; int p; for(i=0; i<10; i++) { scanf("%d",&a[i]); b[i]=a[i]; } for(i=0; i<10; i++) for(j=0; j<10; j++) { if(a[j]>a[j+1]) { p=a[j]; a[j]=a[j+1]; a[j+1]=p; } } for(i=0; i<9; i++) { printf("%d ",a[i]); } printf("%d",a[9]); printf("\n"); for(i=0; i<9; i++) for(j=0; j<10; j++) { if(a[i]==b[j]) printf("%d ",j+1); } for(j=0; j<10; j++) { if(a[9]==b[j]) printf("%d",j+1); } return 0; }

      

     

     

     

     

     

     

    转载请注明原文地址: https://ju.6miu.com/read-2459.html

    最新回复(0)