今日题目
1. 给定两个整形变量的值,将两个值的内容进行交换
2. 求10 个整数中最大值
3. 将三个数按从大到小输出
4. 求两个数的最大公约数
1. 给定两个整形变量的值,将两个值的内容进行交换
我们想交换两个杯子里的水,那么就需要第三个杯子来辅助我们交换,交换两个变量的值也一样,需要创建第三个变量来完成交换
//交换两个数
#include<stdio.h>
#include<stdlib.h>
int main() {
int num1 = 0;
int num2 = 0;
int tmp = 0;
scanf("%d %d", &num1, &num2);
tmp = num1;
num1 = num2;
num2 = tmp;
printf("%d %d", num1, num2);
system("pause");
return 0;
}
运行结果:
那么不创建第三个变量能否完成两个数的交换呢?
当然也是可以的,用简单的加减法就能帮助我们解题
//交换两个数(不用中间变量)
#include<stdio.h>
#include<stdlib.h>
int main() {
int num1 = 0;
int num2 = 0;
scanf("%d %d", &num1, &num2);
num1 = num1 + num2;
num2 = num1 - num2;
num1 = num1 - num2;
printf("%d %d\n", num1, num2);
system("pause");
return 0;
}
运行结果:
2. 求10 个整数中最大值
比较两个数的大小我们都很清楚,比较十个数无非就是拿两个数来比较,然后将大者再与其他的数进行两两比较,最后输出最大值
//求10个整数中最大值
#include<stdio.h>
#include<stdlib.h>
int main() {
int arr[10] = { 1, 3, 5, 7, 9, 2, 4, 6, 8, 10 };
int max = arr[0];
int i = 0;
for (i = 1; i < 10; i++) {
if (arr[i] >= max) {
max = arr[i];
}
}
printf("MAX = %d\n", max);
system("pause");
return 0;
}
运行结果:
3. 将三个数按从大到小输出
又是一道比较大小的题目,我们借助一个临时变量tmp来帮助我们进行比较,两两进行比较,最终把最大值赋给a,较小值赋给b,最小值赋给c,依次打印a,b,c就得到三个数从大到小的排序了
//将三个数从大到小输出
#include<stdio.h>
#include<stdlib.h>
int main() {
int a = 0;
int b = 0;
int c = 0;
int tmp = 0;
scanf("%d %d %d", &a, &b, &c);
//将a,b中的较大值赋给a,较小值赋给b
if (a < b) {
tmp = a;
a = b;
b = tmp;
}
//将a,c中的较大值赋给a,较小值赋给c
if (a < c) {
tmp = a;
a = c;
c = tmp;
}
//将b,c中的较大值赋给b,较小值赋给c
if (b < c) {
tmp = b;
b = c;
c = tmp;
}
printf("%d %d %d\n", a, b, c);
system("pause");
return 0;
}
运行结果:
4. 求两个数的最大公约数
用辗转相除法来实现
//求两个数的最大公约数
#include<stdio.h>
#include<stdlib.h>
int main()
{
int a,b,tmp;
scanf("%d %d",&a,&b);
//保证a为大的,b为小的
if(a < b){
tmp = a;
a = b;
b = tmp;
}
//用a%b,把b的值赋给a,再把取余的值赋给b,当取余为0时,循环跳出,b就是最大公约数
while(a%b != 0){
tmp = a%b;
a = b;
b = tmp;
}
printf("最大公约数为:%d\n",b);
system("pause");
return 0;
}
运行结果:
在C语言中我们通常会借助创建临时变量来帮助我们解决问题,会让问题变得更清晰好解