当前位置: 首页 > news >正文

xtuoj Repeat One

题目

思路

观察

全部由数码1组成的数(如1, 11, 111, 1111, …)永远不能被2或5的倍数整除。

也就是说,任何含有质因数2或5的正整数都无法整除这类数。

原因在于: 这些数总是奇数,因此不能被2整除。 这些数的个位总是1,因此不能被5整除。

如果正整数M与10互质(即M不含质因数2或5),则总存在一个由全1组成的数能被M整除。

因此,永远不能整除全1数的数就是所有2的倍数和5的倍数。 

由于题目最小的由1组成的数是1,用ans表示由N个数码1组成的数,所以ans最小为1,题目求最小的N,所以我们设置ans初始值为1。

从小到大寻找ans,如果ans%M==0,即找到了最小的ans被M整除,那我们就输出ans的位数,所以我们要用一个标记记录ans的位数,这里我采用cnt,并初始化为1,因为ans初始值为1,为1位数。

如果没找到ans,那我们就要继续增加一位1,做法就是ans=ans*10+1,*10相当于向左移动了一位,+1相当于最后一位设置为1,但是我们观察样例输入输出可以看出,ans的结果可能非常大,所以这里我们采用模运算,而且我们判断ans能否被M整除。

把ans拆分为两部分,一部分是M的倍数,这部分必然能被M整除,另外一部分当然就是ans%M后的余数部分,只需要这部分能被M整除,那么整个原来的ans就能被M整除。

代码

#include<stdio.h>
#define ll long longll K,M,ans,cnt;int main(){scanf("%lld",&K);while(K--){scanf("%lld",&M);if(M%2==0||M%5==0){printf("0\n");continue;}ans=1,cnt=1;while(ans%M!=0){ans=(ans*10+1)%M;cnt++;}printf("%lld\n",cnt);}return 0;
}

http://www.dtcms.com/a/515619.html

相关文章:

  • ENSP Pro Lab笔记:配置STP/RSTP/MSTP(3)
  • **发散创新:模拟计算的高级应用与实现**随着科技的飞速发展,模拟计算已经成为了众多领域的核心工
  • EasyGBS如何在平安乡村搭建无线视频联网监控系统?
  • 上新!联软科技发布新一代LeagView平台,用微服务重塑终端安全
  • 【以太来袭】2. 节点设计与部署
  • 增加网站广告位建网站首页图片哪里找
  • Yolo分割数据集错误数据删除
  • Redis原理篇(一)数据结构
  • 1022作业
  • 北京商城型网站建设网上商城的意义
  • 《3D端游云原生日志:开放世界资源加载卡顿的实战与经验沉淀》
  • 2025年渗透测试面试题总结-213(题目+回答)
  • 技术演进中的开发沉思-146 java-servlet:Servlet 在云原生时代的适配”
  • 网件路由器做网站装修公司加盟好还是自己开
  • 【自适应滤波例程】基于新息协方差匹配的自适应EKF (无迹卡尔曼滤波) vs 经典EKF对比,附MATLAB代码下载链接
  • 获得网站源文件破解WordPress站点
  • 【OpenManus深度解析】MetaGPT团队打造的开源AI智能体框架,打破Manus闭源壁垒。包括架构分层、关键技术特点等内容
  • Redis(一):缓存穿透及其解决方法(SpringBoot+mybatis-plus)
  • Tanh 函数详解
  • 【手机篇】AI深度学习在手机中框/RT四周外观检测应用方案
  • 遂宁网站优化东莞市住房和城乡建设局门户网站
  • 基于专家经验的网络异常流量检测技术研究
  • 生成模型实战 | MUNIT详解与实现
  • 网站建设的费用包括微信app下载找回微信
  • JAVA攻防-常规漏洞SQL注入四类型XXE引用点RCE原生框架URL跳转URL处理类
  • Disk Drill Enterprise Windows数据恢复工具
  • 合合信息亮相PRCV:多模态文本智能与内容安全双擎驱动新突破
  • PCIe协议之 Equalization篇 之 理论篇 之 DFE CTLE
  • 接单做一个网站多少钱网站后台修改图片
  • 操作系统4.3.1 文件系统的层次结构