似乎没有!挑几道用代码来解决
4(1)有两个瓶子A和B,分别盛放酱油和醋,要求将他们互换
#include<stdio.h>
int main()
{
int i=10;//设置“醋”
int j=20;//设置“酱油”
printf("交换前:%d %d\n",i,j);
int tmp=0;//设置空瓶
tmp=i;
i=j;
j=tmp;
printf("交换后:%d %d",i,j);
return 0;
}
tmp类似于一个空瓶,没有空瓶的辅助,醋和酱油倒来倒去最终也不会分开,必须要有第三个瓶子来,来辅助。(这个代码后续使用范围很广)
(2)依次将10个数输入,要求输出其中最大的数
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int main()
{
int arr[10] = { 0 };
int i = 0;
for (; i<10; i++)
{
scanf("%d", &arr[i]);
}
for (i = 0; i<9; i++)
{
if (arr[i] >arr[i + 1])
{
int tmp = arr[i];
arr[i] = arr[i + 1];
arr[i + 1] = tmp;
}
}
printf("%d", arr[9]);
return 0;
}
此处应注意一下&符号。
(3)有三个数a,b,c按大小输出
#include<stdio.h>
int main()
{
int a,b,c,tmp;
scanf("%d%d%d",&a,&b,&c);
if(a<b)
{
tmp=a;
a=b;
b=tmp;
}
if(a<c)
{
tmp=a;
a=c;
c=tmp;
}
if(b<c)
{
tmp=b;
b=c;
c=tmp;
}
printf("%d %d %d",a,b,c);
return 0;
}
按照从大到小顺序输出,这里的思路很显然,不改变打印的顺序,改变变量中的值。
(4)判断一个数能否被3和5整除
#include<stdio.h>
int main()
{
int i=0;
scanf("%d",&i);
if(i%5==0&&i%3==0)
{
printf("yes");
}
else
printf("no");
return 0;
}
还有一道素数题,书上例题有解答
而求最大公约数有一个辗转相除法,会在下次与如何求最大公倍数一起讲解
如有错误,欢迎私信我修改。