解题思路:首先想到的就是,两个数之间的公约数和公倍数都可以用整除取余的方式得到,但是我不太想用同一种方法解决两个问题。
所以就使用了不同的方法解决两个问题。
对于最大公约数而言,利用循环遍历所有能整除的数存到数组中,然后再用数组中的元素对另一个数进行整除的操作,从而得到答案。
对于最小公倍数来说,还是利用了传统的,共同整除的方法,得到了所有的公倍数,然后只需要取最后,也就是最小的一位就可以了。
注意事项:
该代码较为简单,注意事项比较少
最主要的就是需要注意两个数之间的公倍数和公约数并不唯一,所以需要判断最大或最小数是哪个。
其次,在利用循环存储的过程中,要注意自加自减的规律,避免数组超限带来的问题。
参考代码:
#include<stdio.h>
int main(){
int n,m,x=0,y=0,z=0;
int a[100],b[100],c[100];
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++){
if(n%i==0){
a[x]=i;
x++;
}
}
for(int j=0;j<=x-1;j++){
if(m%a[j]==0){
b[y]=a[j];
y++;
}
}
printf("%d ",b[y-1]);
for(int k=n*m;k>=m;k--){
if(k%n==0&&k%m==0){
c[z]=k;
z++;
}
}
printf("%d",c[z-1]);
return 0;
}
0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复