***問題:
問題の説明
入力N(N <100)の数、これらの数値その最前出力と前記データ交換最小数を見つけます。
入力
データの入力複数のセット、各ラインにおける各表す1行の整数であり、Nは、このテストケースにおける数値は、N個の整数が続きます。n = 0で処理されていない、入力の終了を示します。
出力
それぞれの場合について、スイッチング出力後の列数、行ごとに各出力。
サンプル入力
4 2 1 3 4
5 4 3 2 1
0
サンプル出力
1 2 3 4
1 4 3 2 5 ***
コード:
#include<iostream>
using namespace std;
int main(){
int a[100];
int n,min;
while(scanf("%d",&n)!=EOF){
int sign=0;
if(n==0){
break;
}
cin>>a[0];
min=a[0];
for(int i=1;i<n;i++){
cin>>a[i];
if(a[i]<min){
min=a[i];
sign=i;//记录下标
}
}
if(sign!=0){
int temp=a[0];
a[0]=min;
a[sign]=temp;
}
for(int i=0;i<n;i++){
if(i!=n-1)
cout<<a[i]<<" ";
else cout<<a[i]<<endl;
}
}
return 0;
}
分析:ここで注意すべき最初のものを持参する入力配列の最初の値が、後者と比較して、その後、彼はデフォルトの最小値になってみましょう、と。インデックスの最小値を見つけることを忘れないでください、そして後者の方が小さい値を持つ場合にのみ、それは、交換する必要がある場合ので、ここに決意