C语言程序题(一)

一.三个整数从大到小输出

首先做这个题目需要知道理清排序的思路,通过比较三个整数的值,使之从大到小输出。解这道题有很多方法我就总结了两种方法:一是通过中间变量比较和交换,二是可以用冒泡排序法(虽然三个数字排序用这个效率低,就是一块总结一下它的大概思路)。

中间变量比较和交换

无论多乱顺序三个数之间都要进行比较(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);
            else
               printf("%d=%d\n",a,b);
        }
    return 0;
}

打印scanf数值取决于输入的个数,如下图:

相关推荐
励志成为嵌入式工程师3 小时前
c语言简单编程练习9
c语言·开发语言·算法·vim
Peter_chq3 小时前
【操作系统】基于环形队列的生产消费模型
linux·c语言·开发语言·c++·后端
hikktn5 小时前
如何在 Rust 中实现内存安全:与 C/C++ 的对比分析
c语言·安全·rust
观音山保我别报错5 小时前
C语言扫雷小游戏
c语言·开发语言·算法
小林熬夜学编程7 小时前
【Linux系统编程】第四十一弹---线程深度解析:从地址空间到多线程实践
linux·c语言·开发语言·c++·算法
墨墨祺8 小时前
嵌入式之C语言(基础篇)
c语言·开发语言
躺不平的理查德8 小时前
数据结构-链表【chapter1】【c语言版】
c语言·开发语言·数据结构·链表·visual studio
幼儿园园霸柒柒9 小时前
第七章: 7.3求一个3*3的整型矩阵对角线元素之和
c语言·c++·算法·矩阵·c#·1024程序员节
好想有猫猫9 小时前
【51单片机】串口通信原理 + 使用
c语言·单片机·嵌入式硬件·51单片机·1024程序员节
摆烂小白敲代码10 小时前
背包九讲——背包问题求方案数
c语言·c++·算法·背包问题·背包问题求方案数