问题 B: 排序问题

    xiaoxiao2021-03-25  240

    题目描述

    输入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> int main() { int a[10], b[10]; int i, j, t; for (i=0; i<10; i++) { scanf("%d", a+i); b[i] = i+1; } for (i=0; i<10; i++) for (j=i+1; j<10; j++) { if (a[i] > a[j]) { t = a[i]; a[i] = a[j]; a[j] = t; t = b[i]; b[i] = b[j]; b[j] = t; } } for (i=0; i<9; i++) printf("%d ", a[i]); printf("%d\n", a[9]); for (i=0; i<9; i++) printf("%d ", b[i]); printf("%d\n", b[9]); return 0; } 运行结果:没截图 在编程训练课堂上遇见的问题,抄了小汪的,留念研究
    转载请注明原文地址: https://ju.6miu.com/read-2047.html

    最新回复(0)