2 实验题二:复杂函数
求用户输入的2个数的最大公约数和最小公倍数。
解题思路:
首先用数学的方法来解决,要求2个数的最大公约数,首先应该把大数的因子一个个找出来,判断是不是小数的因子。因为是最大公约数,所以要从大数的最大因子开始判断。
要找一个数最大因子,可以从N1/2开始依次的减一,如果可以被N1整除,则是因子,再判断是否能被N2整除,如果也可以,那该数即是最大公约数。所以,我们可以采用类似以下的循环来完成:
for(int i=n1/2;i>=2;i--) //请判断i为什么要大于等于2
{
if(n1%i==0) //模一个数等于0,表示能够整除
{
//请在这里自己填入判断i是否是n2的因子的语句
}
}
对于公倍数,似乎更简单。
只要对大数n1进行乘一,乘二,乘三。。。。。。并将每次的结果模小数看结果是否为0即可
虽然有思路,但不是不太会,请高手指点,跪谢!!!!
个人简介: 菜虫,
[此贴子已经被作者于2005-5-27 15:30:25编辑过]
----------------解决方案--------------------------------------------------------
#include <stdio.h> #define bool int #define TRUE 1 #define FALSE 0
void fun(int *y,int *m,int *d) { int a[2][13]={ {0,31,28,31,30,31,30,31,31,30,31,30,31}, {0,31,29,31,30,31,30,31,31,30,31,30,31} }; int year,month,day; int theday; bool isrun=FALSE; int i,j,k;
printf("input the year-month-day:\n"); scanf("%d%d%d",&year,&month,&day); printf("input the day after the date:\n"); scanf("%d",&theday);
for(i=0;i<theday;i++) { isrun=FALSE; if (year%4==0) if (year%100!=0) isrun=TRUE; day++; if (day>a[isrun][month]) { day=1; month++; if (month>12) { year++; month=1; } } } *y=year; *m=month; *d=day; }
void main(void) { int year,month,day;
clrscr(); fun(&year,&month,&day); printf("the date is %04d--%02d--%02d\n",year,month,day); }
----------------解决方案--------------------------------------------------------
谢谢
有没有简单点的
[此贴子已经被作者于2005-5-28 9:16:17编辑过]
----------------解决方案--------------------------------------------------------