| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2611 人关注过本帖
标题:求n个数的最小公倍数
只看楼主 加入收藏
a1067942077
Rank: 2
等 级:论坛游民
帖 子:36
专家分:11
注 册:2016-10-15
结帖率:38.46%
收藏
 问题点数:0 回复次数:1 
求n个数的最小公倍数
输入包含多个测试实例,每个测试实例的开始是一个正整数n,然后是n个正整数。
为每组测试数据输出它们的最小公倍数,每个测试实例的输出占一行。你可以假设最后的输出是一个32位的整数。
Sample Input
2 4 6
3 2 5 7
Sample Output
12
70

#include<stdio.h>
int gcd(int m,int n);
int gcd(int m,int n)
{
    int r;
    if(m<n)
    {
        r=m;
        m=n;
        n=r;
    }
    while(r)
    {
        r=m%n;
        m=n;
        n=r;
    }
    return m;
}
int main()
{
    int n,i,m;
    int sum;
    int a[30];
    while(scanf("%d",&n)!=EOF)
    {
        sum=1;
        for(i=0;i<n;i++)
        scanf(" %d",&a[i]);

        m=gcd(a[0],a[1]);
        for(i=1;i<n;i++)
          m=gcd(m,a[i]);

        for(i=0;i<n;i++)
           sum=sum/m*a[i];
        printf("%d\n",sum*m);
    }
}

Oj上显示答案错误
搜索更多相关主题的帖子: 最小公倍数 include return 正整数 
2016-11-23 16:24
linlulu001
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:20
帖 子:944
专家分:4047
注 册:2016-4-13
收藏
得分:0 
#include<stdio.h>

int gcd(int x,int y);
int main()
{
    unsigned n;
    while(scanf("%u",&n))
    {
        int s=1,k;
        for(int i=0;i<n;++i)
        {
            k=0;
            while(!(scanf("%*c%d",&k))||k==0);        //k读取到 0或者非字数重新输入
            s=s*k/gcd(s,k);
        }
        printf("%d\n",s);
    }
}

int gcd(int x,int y)                   //最大公约数
{
    int max,min;
    max=x>y?x:y;
    min=x<y?x:y;
    while(max%min)
    {
        int x=max%min;
        max=min;
        min=x;
    }
    return min;
}
2016-11-23 17:08
快速回复:求n个数的最小公倍数
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.018373 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved