杭电2016 数据的交换输出
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了杭电2016 数据的交换输出相关的知识,希望对你有一定的参考价值。
Problem Description
输入n(n<100)个数,找出其中最小的数,将它与最前面的数交换后输出这些数。
Input
输入数据有多组,每组占一行,每行的开始是一个整数n,表示这个测试实例的数值的个数,跟着就是n个整数。n=0表示输入的结束,不做处理。
Output
对于每组输入数据,输出交换后的数列,每组输出占一行。
Sample Input
4 2 1 3 4
5 5 4 3 2 1
0
Sample Output
1 2 3 4
1 4 3 2 5
代码:
1 #include<stdio.h> 2 #define maxsize 100 3 int qiuzuixiao(int a[],int n){ 4 int min=*a; 5 int k=0; 6 for(int i=1;i<n;i++){ 7 if(min>a[i]){ 8 min=a[i]; 9 k=i; 10 } 11 } 12 int temp; 13 temp=a[k]; 14 a[k]=a[0]; 15 a[0]=temp; 16 } 17 int main(){ 18 int n=-1; 19 while(scanf("%d",&n)!=EOF&&n!=0&&n<100){ 20 int a[maxsize]; 21 for(int i=0;i<n;i++){ 22 scanf("%d",&a[i]); 23 } 24 qiuzuixiao(a,n); 25 for(int i=0;i<n;i++){ 26 if(i==n-1){ 27 printf("%d\n",a[i]); 28 }else 29 printf("%d ",a[i]); 30 } 31 32 } 33 return 0; 34 }
注意输出格式,一开始没注意,提交显示presentation error,查了下发现结果其实是对的,就是输出格式有误,譬如多了个空格,所以这段代码中加了if判断语句来修改输出格式(就是把最后一个数后面的空格给去掉)
for(int i=0;i<n;i++){ if(i==n-1){ printf("%d\n",a[i]); }else printf("%d ",a[i]); }
好了就这些了
以上是关于杭电2016 数据的交换输出的主要内容,如果未能解决你的问题,请参考以下文章