2017.排序问题

    xiaoxiao2021-03-25  76

    问题及代码:

    Problem B: 排序问题

    Time Limit: 1 Sec   Memory Limit: 64 MB Submit: 804   Solved: 407 [ Submit][ Status][ Web Board]

    Description

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

    Input

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

    Output

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

    Sample Input

    1 2 3 5 4 6 8 9 10 7

    Sample Output

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

    HINT

    #include <stdio.h> #include <stdlib.h> #include<math.h> int main() { int s[80],t[80],a,b,i,j;//定义两个数组,一个储存数据,一个储存顺序 for(i=0; i<10; i++) { scanf("%d",&s[i]); t[i]=i+1; } for(j=0; j<10; j++) for(i=0; i<9; i++) { if(s[i]>s[i+1])//两个数组要一起交换。 { a=s[i]; s[i]=s[i+1]; s[i+1]=a; b=t[i]; t[i]=t[i+1]; t[i+1]=b; } } for(i=0; i<9; i++) printf("%d ",s[i]); printf("%d\n",s[9]);//最后一个输出没有空格 for(i=0; i<9; i++) printf("%d ",t[i]); printf("%d",t[9]); return 0; } 学习心得:OJ上对于题目格式的要求很高,要特别注意、

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

    最新回复(0)