菜蛙


私信TA

用户名:hu2022

访问量:16333

签 名:

明日复明日,明日何其多。我生待明日,万事成蹉跎。

等  级
排  名 546
经  验 4391
参赛次数 0
文章发表 75
年  龄 0
在职情况 学生
学  校 哈工程
专  业

  自我简介:

TA的其他文章

注意事项:

注意先声明再调用哦~
参考代码:

#include<stdio.h>

int main(void){
	int factor(int m,int n);
	int multiple(int m,int n);
	int a,b;
	scanf("%d%d",&a,&b);
	
	printf("%d %d",factor(a,b),multiple(a,b));
	
	return 0;
}

/*
·求最大公因数函数
·for函数执行完一次循环语句后,
会先执行更新语句,再进入判断语句
因此返回值需要加一 
*/
int factor(int m,int n){
	int i,num;
	
	if(m<n){
		num = m;
	}else num = n;
	
	for(i=1;i>0;num--){
		if(m%num==0&&n%num==0){
			i = 0;
		}
	}
	return num+1;
}
/*
·求最小公倍数函数
·调用factor函数前,一定要先声明一下 
*/
int multiple(int p,int q){
	int factor(int m,int n);
	int mul;
	
	mul = (p/factor(p,q)) * (q/factor(p,q)) * factor(p,q);
	
	return mul;
}

写在最后:从本题不难看出,函数虽然听着很高端洋气,但是这种简单问题用函数解决的话,会将问题复杂化。举个栗子,之前做过的1011题也是求公因子和公倍数,没用函数做起来代码更为简洁哎。

题目链接:https://www.dotcpp.com/oj/problem1011.html
我的题解:https://blog.dotcpp.com/a/88925

所以说杀鸡焉用牛刀,好钢也要用在刀刃上~

不过按照学习的进度,现在的水平确实只能用这样的题目练习函数啦~

 

0.0分

0 人评分

  评论区

  • «
  • »