暑假超越计划练习题(4)

本文作者分享了C语言学习过程中的几道经典练习题,包括不使用临时变量交换两个数、找出10个整数中的最大值、按从大到小输出三个数以及计算两个数的最大公约数。通过代码示例展示了各种解题方法,并鼓励读者进行实践和复习。
摘要由CSDN通过智能技术生成

笔者开头感想:现如今,暑假已经过大半部分,但是随着时间流逝,笔者的C语言仍没有多大的起色,日新月急,但是没有办法,思前想后,笔者决定对于之前所学的内容进行一下回顾复习!因此刷题是必须的,所以笔者将最近做过的习题,将会在此整理一遍,重新整理成为一个C语言练习题集册,笔者也会将最近书写过的习题,统一归纳到该C语言练习题集册里面,供笔者借鉴参考!
 

暑假超越计划,简短练习题:

1. 给定两个整形变量的值,将两个值的内容进行交换。
2. 不允许创建临时变量,交换两个数的内容(附加题)
3.求10 个整数中最大值。
4.将三个数按从大到小输出。
5.求两个数的最大公约数。

笔者不才!最近斗胆创建了一个名为C语言大家庭的公众号,里面记录了笔者之前的CSDN文章,感兴趣的读者请添加关注哦!

最近刚刚开始起步,急剧寻找合作伙伴!有意者请一步微信公众号私聊

 1. 给定两个整形变量的值,将两个值的内容进行交换。

笔者的简单代码为:

//1. 给定两个整形变量的值,将两个值的内容进行交换。
#include <stdio.h>
int main()
{
	int a = 10;
	int b = 20;

	printf("a=%d   b=%d\n", a, b);

	int tmp = 0;
	tmp = a;
	a = b;
	b = tmp;

	printf("a=%d   b=%d\n", a, b);
	return 0;
}

该段代码的主要精华在于,创建了一个临时变量来作为中间值去接受,交换!

该段代码的运行结果为:

 2. 不允许创建临时变量,交换两个数的内容(附加题)

笔者的简短代码为:

//2. 不允许创建临时变量,交换两个数的内容(附加题)
#include <stdio.h>
int main()
{
	int a = 0;
	int b = 0;
	scanf_s("%d %d", &a, &b);
	printf("a=%d b=%d\n", a, b);
	a = a + b;
	b = a - b;
	a = a - b;
	printf("a=%d b=%d\n", a, b);
	return 0;
}

 在上述代码中,笔者没有创建其他的临时变量来接受交换两个值,仅仅依靠……!

上述代码的运行结果为:

 

通过上述代码,对于加减乘除四则运算一共有四种不同的写法!下面笔者在写一种其他的方法!


//2. 不允许创建临时变量,交换两个数的内容(附加题)

#include <stdio.h>
int main()
{
	int a = 0;
	int b = 0;
	scanf_s("%d %d", &a, &b);
	printf("a=%d b=%d\n", a, b);
	a = a ^ b;
	b = a ^ b;
	a = a ^ b;
	printf("a=%d b=%d\n", a, b);
	return 0;
}

上述代码段主要用了按位异或" ^ ",操作符!对于按位异或操作符不懂的读者,请参考笔者之前博客,有过详细的解答!在此就不做过多的讲述!链接在此:浅识C语言中那些操作符(保证足够详细)_念君思宁的博客-CSDN博客

请读者认真参考!

为了区别与第一个代码的运行结果,笔者随机输入了三位数:

代码的运行结果为:

 3.求10 个整数中最大值。

对于10个数字我们该怎样输入???

下面请看笔者的代码:
 

//3.求10 个整数中最大值。

#include <stdio.h>
int main()
{
	int arr[10] = { 0 };
	int i = 0;

	for (i = 0; i < 10; i++)
	{
		scanf_s("%d", &arr[i]);
	}

	int max = arr[0];

	for (i = 0; i < 10; i++)
	{
		if (max <= arr[i])
			max = arr[i];
	}

	printf("%d\n", max);
	return 0;
}

代码的运行结果为:(数字为笔者随机输入)

 4.将三个数按从大到小输出。

请看笔者的代码:


4.将三个数按从大到小输出。
#include<stdio.h>
int main()
{
	int a, b, c, t;
	printf("请输入三个整数:\n");
	scanf_s("%d\t%d\t%d", &a, &b, &c);
	if (a > b)
	{
		t = a;
		a = b;
		b = t;
	}
	if (a > c)
	{
		t = a;
		a = c;
		c = t;
	}
	if (b > c)
	{
		t = b;
		b = c;
		c = t;
	}
	//注意从小到大的顺序 : c>b>a!
	printf("将这三个数按从大到小的顺序排列为:%d\t%d\t%d\n", c, b, a);
	return 0;
}

当然对于上述代码也可以用数组的形式来书写,在这里,笔者就不做过多的讲述!

代码的运行结果为:

5.求两个数的公约数。

笔者的简单代码为:

#include <stdio.h>
int main()
{
	int a = 0;
	int b = 0;
	scanf_s("%d %d", &a, &b);

	int min = a < b ? a : b;
	int i = 0;

	for (i = min; i > 1; i--)
	{
		if ((a % i == 0) && (b % i == 0))
			printf("%d ", i);
	}

	if (i == 1)
		printf("%d\n",i);
	return 0;
}

代码的运行结果为:

 如今已经坚持了四天,距离开学也不远了,希望笔者能够全部坚持下去!加油!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

念君思宁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值