起因:刷洛谷题单
最初的思考,如果要实现3个数的比较,要写整整A33(排列数)种比较,还要考虑数值相等的情况,烦死了。于是打开网上找思路。
发现新思路:不用一个数一个数比较,进行位置比较,比如在从小到大的顺序中,左边的位置中的值理应比右边小,那么直接进行位置比较并交换数值就好了。
实现的代码:
#include <stdio.h>
int main()
{
int i,t,c,tmp,array[100^10];
char flag='a';
t=0;
for ( i = 0; i < 100^10&&flag!='\n'; i++)//getchar函数可以读取已读字符后面第一个未读字符
{
scanf("%d",&array[i]);//数组中第一个元素对应的索引号值为0
flag=getchar();
t++;
}
for ( i = 0; i<t; i++)//实现对位置的遍历
{
for ( c=i+1; c<t;c++)//实现本位置对所有的后面的位置的“值比较”,并实现“值换位”
{
if (array[i]>array[c])
{
tmp=array[i];
array[i]=array[c];
array[c]=tmp;
}
}
}
for ( i = 0; i < t; i++)
{
printf("%d ",array[i]);
}
return 0;
}