| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 901 人关注过本帖
标题:关于最大公约数的问题,请大家看下我的代码
只看楼主 加入收藏
lstary
Rank: 1
等 级:新手上路
帖 子:70
专家分:0
注 册:2008-1-21
收藏
 问题点数:0 回复次数:9 
关于最大公约数的问题,请大家看下我的代码
在编译的时候可以,但是在运行的时候却出现了问题,请大家帮我看一下,另外有没有关于最大公约数问题的比较简单的算法?

main()
{
int a,b,c;
scanf("%d,%d",&a,&b);
c=division(a,b);
printf("the number is %d",c);
}
#include <stdio.h>
int division(int x,int y)
{
int i,j,c;
char str1[81];
char str2[81];
for(i=1;i<=x;i++)
if(x%i==0) gets(str1);
for(j=1;j<=y;j++)
if(y%j==0)get(str2);
strcpy(str1,str2);
c=max(str1);
return c;
}
max(int a[])
{
int i,t=a[0];
for(i=1;i<'\0';i++)
if(t<a[i])t=a[i];
return t;
}
搜索更多相关主题的帖子: int 最大公约数 division 代码 
2008-01-28 11:36
josen0205
Rank: 2
来 自:江苏
等 级:论坛游民
帖 子:307
专家分:52
注 册:2007-5-8
收藏
得分:0 
#include <stdio.h>

int fun(int m, int n)
{
    int t;
    while(m%n)
    {
        t = m%n;
        m = n;
        n = t;
    }
    return n;
}

int main()
{
    printf("%d\n", fun(8,42));
    return 0;
}

只有想不到,没有做不到
2008-01-28 11:43
sxn0508
Rank: 1
等 级:新手上路
帖 子:120
专家分:0
注 册:2008-1-24
收藏
得分:0 
程序代码:
int fun(int m, int n)
{
    if(m%n!=0)
        return fun(n, m%n);
    else
        return n;
}
int main()
{
    printf("%d\n", fun(8,42));
    return 0;
}
2008-01-28 12:44
lstary
Rank: 1
等 级:新手上路
帖 子:70
专家分:0
注 册:2008-1-21
收藏
得分:0 
很感谢楼上两位朋友对我提出的算法作出的解答,你们的算法很简单,我采取了。但是可以帮我解释一下我的错在哪里么?
2008-01-28 19:22
lstary
Rank: 1
等 级:新手上路
帖 子:70
专家分:0
注 册:2008-1-21
收藏
得分:0 
真的没人可为这个问题作出解答么??
2008-01-28 22:36
sxn0508
Rank: 1
等 级:新手上路
帖 子:120
专家分:0
注 册:2008-1-24
收藏
得分:0 
[bo]以下是引用 [un]lstary[/un] 在 2008-1-28 11:36 的发言:[/bo]

main()
{
int a,b,c;
scanf("%d,%d",&a,&b);
c=division(a,b);
printf("the number is %d",c);
}
#include <stdio.h>
int division(int x,int y)
{
int i,j,c;
char str1[81];
char str2[81];
for(i=1;i<=x;i++)
if(x%i==0) gets(str1);
for(j=1;j<=y;j++)
if(y%j==0)get(str2);
strcpy(str1,str2);
c=max(str1);
return c;
}
max(int a[])
{
int i,t=a[0];
for(i=1;i<'\0';i++)
if(t<a[i])t=a[i];
return t;
}

1、我觉得#include <stdio.h>最好放在顶上
2、自定义函数放在main下面的话最好能在main之上声明一下
3、max函数应该定义个类型,不然怎么return t;
4、gets函数用的不太妥当,还有个gets掉了s
5、strcpy用的更是不知所谓
6、这个for(i=1;i<'\0';i++)就更无语了
7、还有很多问题,我就不一一列举了

[[it] 本帖最后由 sxn0508 于 2008-1-29 08:54 编辑 [/it]]
2008-01-29 08:42
sxn0508
Rank: 1
等 级:新手上路
帖 子:120
专家分:0
注 册:2008-1-24
收藏
得分:0 
[bo]以下是引用 [un]lstary[/un] 在 2008-1-28 22:36 的发言:[/bo]

真的没人可为这个问题作出解答么??

我改了改你的程序,估计能用了,不过有待改进

程序代码:
#include <stdio.h>
int max(int a[],int b[])
{
   int i=0,j=0,t=0;
   while(a[i]!=0)
   {
      j=0;
      while(b[j]!=0)
      {
         if(a[i]==b[j])
         {
            if(t<a[i])
            {
               t=a[i];
               i++;
            }
         }
         j++;
      }
      i++;
   }
   return t;
}

int division(int x,int y)
{
   int i,j,c;
   int str1[81]={};
   int str2[81]={};
   c=0;
   for(i=1;i<=x;i++)
      if(x%i==0)
      {
         str1[c]=i;
         c++;
      }
   c=0;
   for(j=1;j<=y;j++)
      if(y%j==0)
      {
         str2[c]=j;
         c++;
      }
   c=max(str1,str2);
   return c;
}

main()
{
   int a,b,c;
   scanf("%d,%d",&a,&b);
   c=division(a,b);
   printf("the number is %d",c);
}
2008-01-29 09:27
lstary
Rank: 1
等 级:新手上路
帖 子:70
专家分:0
注 册:2008-1-21
收藏
得分:0 
谢谢上面内位朋友,我对你的帮助真的不胜感激,我现在改进了算法,与你分享一下
main()
{
int a,b,c;
scanf("%d,%d",&a,&b);
c=division(a,b);
printf("the number is %d",c);
}
#include <stdio.h>
int division(int x,int y)
{
    int i,j,c;
    int str1[81];
    if(x>y)c=y;
    else c=x;
    for(i=1,j=0;i<=c;i++)
    {
        if(x%i==0&&y%i==0)
        {
            str1[j++]=i;
            
        }
    }
    c=str1[j-1];
return c;
}
2008-01-29 12:44
lstary
Rank: 1
等 级:新手上路
帖 子:70
专家分:0
注 册:2008-1-21
收藏
得分:0 
[bo]以下是引用 [un]sxn0508[/un] 在 2008-1-29 09:27 的发言:[/bo]


我改了改你的程序,估计能用了,不过有待改进

#include
int max(int a[],int b[])
{
   int i=0,j=0,t=0;
   while(a!=0)
   {
      j=0;
      while(b[j]!=0)
      {
         if(a==b[j])
         {
           ...

我觉得不用定义这两个数组吧:  int str1[81]={};
   int str2[81]={};
我觉得直接
int str1[81];
int str2[82];
就行了吧
2008-01-29 12:50
sxn0508
Rank: 1
等 级:新手上路
帖 子:120
专家分:0
注 册:2008-1-24
收藏
得分:0 
[bo]以下是引用 [un]lstary[/un] 在 2008-1-29 12:50 的发言:[/bo]

我觉得不用定义这两个数组吧:  int str1[81]={};
   int str2[81]={};
我觉得直接
int str1[81];
int str2[82];
就行了吧

   int str2[81]={};这样是为了顺便把值全置为0
2008-01-29 16:53
快速回复:关于最大公约数的问题,请大家看下我的代码
数据加载中...
 
   



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

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