//1. 给定两个整形变量的值,将两个值的内容进行交换。
此题的思路比较简单,两数要进行交换,只需要增加一个变量"temp",来保存交换时候的中间变量即可。
#include<stdio.h>
int main(){
int i,j,t=0;
printf("输入两个数的值:\n");
scanf("%d %d",&i,&j);
t=i;
i=j;
j=t;
printf("输出两个数的值为:\n");
printf("i=%d\nj=%d\n",i,j);
return 0;
}
//2. 给定两个整形变量的值,将两个值的内容进行交换。(不用变量)
可以运用 b=a+b-a; (总和减去之前a)
a=a+b-b;
#include<stdio.h>
int main(){
int i,j;
printf("输入两个数的值:\n");
scanf("%d,%d",&i,&j);
i=i+j;
j=i-j;//将I的值间接给了j
i=i-j;
printf("输出两个数的值为:\n");
printf("i=%d\nj=%d\n",i,j);
return 0;
}
3.10个数里面的最大数
利用一个暂存变量,第一个数赋值给第一个数,然后遍历整个数组即可。
#include<stdio.h>
#define N 10
int main(){
int i,a[N],MAX;
printf("输入十个数:\n");
for(i=0;i<N;i++)
scanf("%d",&a[i]);
MAX=a[0];
for(i=1;i<N;i++){
if(MAX<a[i]){
MAX=a[i];
}
}
printf("最大的数字为:%d\n",MAX);
return 0;
}
4.排序输出
#include<stdio.h>
int main(){
int a,b,c;
printf("依次输入三个数:\n");
scanf("%d,%d,%d",&a,&b,&c);
if(a>b){
if(a>c){
if(b>c) printf("依次为:%d %d %d\n",a,b,c);
else printf("依次为:%d %d %d\n",a,c,b);
}
}
if(b>a){
if(b>c)
if(a>c)
printf("依次为:%d %d %d\n",b,a,c);
else printf("依次为:%d %d %d\n",b,c,a);
}
if(c>b){
if(c>a)
if(a>b)
printf("依次为:%d %d %d\n",c,a,b);
else printf("依次为:%d %d %d\n",c,b,a);
}
return 0;
}
5.求两个数的最大公约数。
利用辗转相除法计算最大公约数
利用B%A
如果A大于B数,交换
1.C=B%A;
2.A=B;
3.C=A;
4.C是否为0,为零输出A的值,不为的话返回1执行。
#include<stdio.h>
int main(){
int a,b,c,temp;
printf("依次输入两个数:\n");
scanf("%d,%d",&a,&b);
if(a>b){
temp=a;
a=b;
b=temp;
}
c=b%a;
while(c!=0){
b=a;
a=c;
c=b%a;
}
printf("最大的公约数为:%d\n",a);
return 0;
}