晓之影 发表于 2020-10-29 15:02:53

大一pta

题目:
7-2 最大公约数和最小公倍数 (10分)

本题要求两个给定正整数的最大公约数和最小公倍数。
输入格式:
输入在一行中给出两个正整数M和N(≤1000)。
输出格式:
在一行中顺序输出M和N的最大公约数和最小公倍数,两数字间以1空格分隔。
输入样例:
511 292

输出样例:
73 2044

#include<stdio.h>
int main()
{
        int m,n,r,b,c,d;
        scanf("%d %d",&m,&n);
        if(m>0&&m<=1000&&n>0&&n<=1000)
        {
          c=m;
          d=n;
            if(m>=n)
          {
                  r=m%n;
                  while(r>0)
                  {
                          r=m%n;
                            m=n;
                          n=r;
                  }
                  b=c*d/m;
                  printf("%d %d\n",m,b);
            }
          else
            {
                  r=n%m;
                  while(r>0)
                  {
                          r=n%m;
                            n=m;
                          m=r;
                  }
                  b=c*d/n;
                  printf("%d %d\n",n,b);
            }
        }
    else
      printf("%d %d\n",c,d);
}
a.c: In function ‘main’:
a.c:5:2: warning: ignoring return value of ‘scanf’, declared with attribute warn_unused_result [-Wunused-result]
scanf("%d %d",&m,&n);
第二个和第三个测试点答案错误,请问这个哪里有问题啊

jackz007 发表于 2020-10-29 16:00:36

#include <stdio.h>

int gcd(int x , int y)
{
      int t                               ;
      while(y) {
                t = x % y                   ;
                x = y                     ;
                y = t                     ;
      }
      return x                            ;
}

main(void)
{
      int b , d1 , d2                     ;
      scanf("%d%d" , & d1 , & d2)         ;
      b = gcd(d1 , d2)                  ;
      printf("%d %d\n" , b , d1 * d2 / b) ;
}
页: [1]
查看完整版本: 大一pta