林间晚来榕 2020-12-06 14:04 采纳率: 100%
浏览 23
已采纳

大佬们帮帮忙!求光棍数问题

求光棍数的,当被除数大于50左右就无法输出正确结果了,这要怎么办

#include <stdio.h>
#include <math.h>
int main (void)
{
    long long int s=0,m;
    long long int x=1;
    scanf("%lld",&m);
    while(1)
    {
        x=x*10+1;
        if(x%m==0) 
        {
            s=x/m;break;
        }
    }
    long long int c=1;
    int n=0;
    while(x/c>0)
    {
        c=c*10;n++;
    }
    printf("%lld %d",s,n);
    return 0;
}

  • 写回答

8条回答 默认 最新

  • 鲛人泣珠 2020-12-08 01:14
    关注

    #include<string.h>
    #include<stdio.h>
    #include<stdlib.h>
    #include<math.h>
    int main()
    {
              int num1;
            char num3[256],num2[256];
            long double num4,num5;
            num4=0;
            scanf("%d",&num1);
            for(int i=0;i<128;i++)
            {
                    num3[i]='1';
                    num3[i+1]='\0';
                    num4=strtold(num3,NULL)/num1;
                    sprintf(num2,"%Lf",num4);
                    if(strstr(num2,"000000")!=NULL)
                    {
                       printf("%.0Lf\n",num4);
                       printf("光棍数是%d\n",i);
                       break;
                    }

            }
            return 0;
    }       
    ~


    最终修改版,使用浮点数替代之前整数,可以输出s以及光棍数n。经过验证,可以处理大型奇数999。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(7条)

报告相同问题?

悬赏问题

  • ¥15 Bibtex4Word 引用中文文献
  • ¥20 用opencv c/c++ 转换成灰度图,然后做一下直方图均衡,输出mp4文件
  • ¥20 matlab中的双层数值积分
  • ¥50 服务器打印水晶报表问题
  • ¥30 gradle环境下javafx项目如何使用druid连接池
  • ¥15 服务器打印水晶报表问题
  • ¥18 深度学习tensorflow1,ssdv1,coco数据集训练一个模型
  • ¥100 关于注册表摄像头和麦克风的问题
  • ¥30 代码本地运行正常,但是TOMCAT部署时闪退
  • ¥15 关于#python#的问题