鱼C论坛

 找回密码
 立即注册
查看: 3406|回复: 11

{求助}小弟用辗转相除法写的求最大公约数和最小公倍数的代码,大家帮忙看下问题

[复制链接]
发表于 2015-5-30 14:11:40 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include "stdio.h"
int main()
{
void yue(int x,int y);
void pei(int x,int y);
int i,j;
scanf("%d,%d",&i,&j);
yue(i,j);
pei(i,j);
}



void yue(int x,int y)
{
int a,b,c;
if(x>y)
{a=x;b=y;}
else
{a=y;b=x;}
for(;c!=0;)
{
        c=a%b;
        if(c==0)break;
        a=b;
        b=c;
       
}
printf("最大公约数是%d\n",b);
}


void pei(int x,int y)
{
int a,b,c,d,k;
k=x*y;
if(x>y)
{a=x;b=y;}
else
{a=y;b=x;}
for(;c!=0;)
{
        c=a%b;
        if(c==0)break;
        a=b;
        b=c;
       
}
d=k/b;
printf("最小公倍数是%d\n",d);
}



求最小公倍数那里除了问题,大神帮忙看下怎么改,顺便问下还有没有更简单的算法。谢谢各位大哥

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2015-5-30 14:19:29 | 显示全部楼层
感觉挺冷清的,这个时候都在陪女票吗?:cry
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2015-5-30 14:33:53 | 显示全部楼层
没热心的前辈人愿意帮忙吗?:mad:
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-5-30 19:04:02 | 显示全部楼层
那个,试了一下,结果没问题啊。
360截图20150530190243390.jpg
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-5-30 19:16:20 | 显示全部楼层
借鉴一下你的算法,咱也写一个。
#include <stdio.h>
#include <conio.h>

int fun(int a, int b)
{
        int t;
        
        if(a < b)
        {
                t = a;
                a = b;
                b = t;
        }
        
        do
        {
                t = a % b;
                a = b;
                b = t;
        }while( t );
        
        return a;
}

int main()
{
        int a, b, t;
        
        printf("请输入两个正整数, 中间用空格隔开: ");
        scanf("%d %d", &a, &b);
        
        t = fun(a, b);
        
        printf("最大公约数为: %d\n", t );
        printf("最小公倍数为: %d\n", (a*b) / t );
        
        getch();
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-5-30 23:19:09 | 显示全部楼层
结果没问题啊,就是代码太多了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-5-31 08:52:49 | 显示全部楼层
:big
int gcd( int x,int y ){
        return y == 0 ? x : gcd( y,x % y ); 
}

int lcm( int x,int y ){
        return ( x * y ) / gcd( x,y );
}

评分

参与人数 2荣誉 +5 鱼币 +10 贡献 +5 收起 理由
康小泡 + 5 + 5 金典的迭代
~风介~ + 5 + 5 有才!

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2015-6-1 12:04:22 | 显示全部楼层
高代知识
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-6-1 12:14:01 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2015-6-2 23:19:01 | 显示全部楼层
桃花飞舞 发表于 2015-5-30 23:19
结果没问题啊,就是代码太多了。

谢谢啊,刚学代码,新手还不是很精练。有朋友帮我看了一下,应该把c!=0这语句删除掉的;因为循环开始时c变量并没有赋值
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2015-6-2 23:19:58 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-6-6 09:11:56 | 显示全部楼层
我用的都是小学的知识。路过....
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-26 01:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表