一.三个整数从大到小输出
首先做这个题目需要知道理清排序的思路,通过比较三个整数的值,使之从大到小输出。解这道题有很多方法我就总结了两种方法:一是通过中间变量比较和交换,二是可以用冒泡排序法(虽然三个数字排序用这个效率低,就是一块总结一下它的大概思路)。
中间变量比较和交换
无论多乱顺序三个数之间都要进行比较(a与b,b与c,c与a),才能比较它们之间的大小。输出从大到小分别把这些数据进行交换,a显示的是三个数字中最大的,c则是最小的数字,其次就是b。
在a和b中,需要比较a与b的大小,a需要三个数字最大的,所以a大于b的话就不需要进行交换,反之用中间变量t进行交换;然后再用a和b中最大的a与c比较,同样的原理大的值复制给a,小的则给另一个(只要有交换就需要用到中间变量t);最后就是b和c之间的大小比较了,同样c最小,把大的值赋值给b,小的值给c。这样下来三个数就比较好了,下面是代码:
int main()
{int a = 0;int b = 0;int c = 0;int t = 0;scanf("%d %d %d", &a, &b, &c);if (a < b)//比较a和b,大的值给a,小的值给b{t = b;b = a;a = t;}if (b < c)//比较b和c,大的值给b,小的值给c{t = c;c = b;b = t;}if (a < c)//比较a和c,大的值给a,小的值给c{t = c;c = a;a = t;}printf("%d %d %d\n", a, b, c);//从大到小输出return 0;
}
冒泡排序比较
首先把这些个数依次放入数组里。然后进入第一次循环,先将前两个数进行从大到小(从小到大),把大的数放入前面,小(大)的放后面,再将小的数和下一个数比较继续小(大)的放后面,直至最后一个数是所有数中最小(大)的,这一趟下来需要比较n-1次;接着我讲下一趟,下一趟和之前差不多,就是数组中最后一个数已经确定了就不需要比大小了,所以两个数比较需要n-2;依次往下推,可以发现规律n-i(其中i为趟数)。(还有这里的趟数是从1开始的)
那需要多少趟呢?按照上面所说的,一趟则确定一个无序数列中最小(大)的,那就需要n趟。但是呢,你想想看就三个数而言,已经确定了两个数那最后一个也确定了,所以一共需要n-1趟。
int main()
{int a[3] = { 0 };int i = 0;int j = 0;int t = 0;for (i = 0; i < 3; i++){scanf("%d", &a[i]);//输入三个数字}for (i = 1; i < 3; i++)//三个数,当两个数确定了位置,最后一个也就确定了。所以需要两趟。{for (j = 0; j < 3-i ; j++){if (a[j] < a[j + 1])//两个相邻的元素进行比较,第一趟完后,最小的数就在末尾了{ //类推下去。每一趟最小的都在最后,顺序就排好了t = a[j];a[j] = a[j + 1];a[j + 1] = t;}}}for (i = 0; i < 3; i++){printf("%d ", a[i]);//打印从大到小的数}return 0;
}
二.输入多个学生的多个成绩,输出学生们的成绩及总分
这里我是用了一个二维数组来存取学生们的成绩, 在这里我强调一下用scanf时需要谨慎使用空格( )和换行(\n)。其次就是打印各项成绩及总成绩。
也可以用一个一维数组,用二维数组更占空间,但二维数组更方便一些。
int main()
{int i = 0;int j = 0;float sum = 0.0f;float arr[5][5] ;for (i = 0; i < 5; i++){for (j = 0; j < 5; j++){scanf("%f", &arr[i][j]);//输入多个学生的多项成绩}}for (i = 0; i < 5; i++){for (j = 0; j < 5; j++){printf("%.1f ", arr[i][j]);//打印学生的各个成绩sum += arr[i][j];//累加计算总成绩}printf("%.1f\n", sum);//打印一个学生的总成绩sum = 0;//初始化}return 0;
}
三. 多组数据比较两个数的大小关系
我一开始做这题程序只能运行一组数据,当时也没有理解多组数据什么意思,后面理解了,所以想记录一下这道题。想要多组数据可以这样写:
int main()
{int a = 0;int b = 0;while (scanf("%d %d", &a, &b) == 2)//重点在这行代码,也可以写成 != EOF{if (a > b)printf("%d>%d\n",a,b);else if (a < b)printf("%d<%d\n",a,b);elseprintf("%d=%d\n",a,b);}return 0;
}
打印scanf数值取决于输入的个数,如下图: