[出力] acm2016交換データ

***問題:
問題の説明
入力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;
}

分析:ここで注意すべき最初のものを持参する入力配列の最初の値が、後者と比較して、その後、彼はデフォルトの最小値になってみましょう、と。インデックスの最小値を見つけることを忘れないでください、そして後者の方が小さい値を持つ場合にのみ、それは、交換する必要がある場合ので、ここに決意

公開された42元の記事 ウォン称賛18 ビュー405

おすすめ

転載: blog.csdn.net/weixin_42918559/article/details/104041705