【NYOJ】[acm-135]三个数从小到大排序

文章字数:232

问题描述

问题分析

我在想上传这题目的意义……
嗯……
主要是感觉既然都是颓废
那就选一个花式的颓废姿势……
就算补上之前没写的题目嘛~

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
#include<stdio.h>
#include<algorithm>
using namespace std;
int main(){
	int a[3];
	while(scanf("%d %d %d",&a[0],&a[1],&a[2])!=EOF){
		sort(a,a+3);
		printf("%d %d %d\n",a[0],a[1],a[2]);
	}
}

也就标程还有点讨论意义
这写的是真抽……
也算培养了程序阅读能力……

标程的思路是通过循环来查找
进而进行排序

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
#include <stdio.h>
int main() {
	int a,b,c,an[3],i,t,j,max,flag;
	scanf ("%d %d %d",&an[0],&an[1],&an[2]);
	for (i=0; i<3; i++) {
		t=max=an[i];
		flag=i;
		for (j=i; j<3; j++)
			if (an[j]>t) {
				max=an[j];
				flag=j;
			}; //加不加;应该都行 
		t=an[i];
		an[i]=max;
		an[flag]=t;
	}
	for (i=2; i>=0; i--)
		printf ("%d ",an[i]);
	return 0;
}

题目地址:#135. 三个数从小到大排序

加载中...