P1091 N-自守数
如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为“N-自守数”。例如 3,而 2 的末尾两位正好是 9,所以 9 是一个 3-自守数。
本题就请你编写程序判断一个给定的数字是否关于某个 N 是 N-自守数。
输入格式:
输入在第一行中给出正整数 M(≤),随后一行给出 M 个待检测的、不超过 1000 的正整数。
输出格式:
对每个需要检测的数字,如果它是 N-自守数就在一行中输出最小的 N 和 NK2 的值,以一个空格隔开;否则输出 No。注意题目保证 0。
输入样例:
3
92 5 233
输出样例:
3 25392
1 25
No
这道题我偷了一下懒,直接使用sprintf将K, K*K*i写入两个字符数组buf1, buf2,然后用strcmp检测 buf1 与 buf2 + strlen(buf2)- strlen(buf1)是不是相等,相等就返回i,全程没动脑子,暴力解决,我的自守数判断函数,题目说K 不大于 1000 ,那,K的数组只需要 4+1,即可, K2 * n 最大也只能是 1000 * 1000 * 10 = 10000000 ,所以数组长度只需要8+1
int isSDnumber(int K)
{
char buf1[5] = {0}, buf2[9] = {0};
int square = K * K; sprintf(buf1, "%d", K); for (int i = 0; i <= 10; i++)
{
sprintf(buf2, "%d", square * i);
int len = strlen(buf2) - strlen(buf1);
if (0 == strcmp(buf1, buf2 + len))
{
return i;
}
}
return -1;
}
完整代码:
更新 2020-02-14:好吧,小姐姐有投诉我懒了,所以我写了非字符数组的版本的检测
在PAT上提交总体时间耗时比用字符长……
int compare(int x, int k)
{
while (k != 0)
{
int t1 = x % 10;
int t2 = k % 10;
if (t1 != t2)
{
return 0;
}
x /= 10;
k /= 10;
}
return 1;
}
2020-02-1411:58:45 更新:完整的判断函数:
我测试过了,clock出来,这个方法跑完样例1,会比字符数组的块一些,我也不知道为什么,PAT里提交平均水平下字符数组会比较快
好吧,现在我知道了,这个方法对于不是自守数的数会快很多,
对于整个数组测试组数为5 且全为非自守数且全为999,这种极端情况下,大概快9倍,
对于整个数组测试组数为5 且全为自守数并且为1000,这种极端情况下,字符数组方法比非字符快10倍左右
对于整个数组测试组数为5 且全为自守数并且为1000,这种极端情况下,差不多持平
int isSDnumber(int k)
{
for (int i = 0; i <= 10; i++)
{
int temp = k;
int square = (i * k * k);
while (temp != 0)
{
int t1 = square % 10;
int t2 = temp % 10;
if (t1 != t2)
{
break;
}
square /= 10;
temp /= 10;
}
if (i > 0 && 0 == temp)
{
return i;
}
}
return -1;
}
完整代码:
PAT不易,诸君共勉!
P1091 N-自守数的更多相关文章
- HW--自守数
package testcase; import huawei.Demo; import junit.framework.TestCase;//加入测试框架,不需要写Main函数 public cla ...
- C语言之自守数
自守数 自守数是指一个数的平方的尾数等于该数自身的自然数,如25*25=625,76*76=5776.要求求出一定范围内的所有自守数. 题目分析: 刚拿到这个题目的时候认为解题关键在于,测试该数平方数 ...
- 自守数算法----C语言实现
#include <stdio.h> //自守数算法 //ep : 25 ^ 2 = 625 76 ^ 2 = 5776 9376 ^ 2 = 87909376 /*ep : * 376 ...
- 1091 N-自守数
如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为“N-自守数”.例如 3×922=25392,而 25392 的末尾两位正好是 92,所以 92 是一个 3-自守 ...
- PAT 乙级 1091 N-自守数 (15 分)
1091 N-自守数 (15 分) 如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为“N-自守数”.例如 3×922=25392,而 25392 的末尾两位正好是 ...
- pat乙级 1091 N-自守数 (15 分)
如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为“N-自守数”.例如 3×922=25392,而 25392 的末尾两位正好是 92,所以 92 是一个 3-自守 ...
- 1091 N-自守数 (15 分)
如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为“N-自守数”.例如 3×922=25392,而 25392 的末尾两位正好是 92,所以 92 是一个 3-自守 ...
- B1091 N-自守数 (15分)
B1091 N-自守数 (15分) 如果某个数 \(K\)的平方乘以\(N\) 以后,结果的末尾几位数等于 \(K\),那么就称这个数为"\(N\)-自守数".例如 \(3×92 ...
- PAT 乙级 1091.N-自守数 C++/Java
题目来源 如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为“N-自守数”.例如 3,而 2 的末尾两位正好是 9,所以 9 是一个 3-自守数. 本题就请你编写程序判断 ...
随机推荐
- php 高级 PHP的垃圾回收机制
PHP可以自动进行内存管理,清楚不再需要的对象.PHP使用了引用计数这种单纯的垃圾回收机制.每个对象都内含一个引用计数器,每个reference链接到对象,计数器加1,当reference离开生存空间 ...
- SpringBoot+JWT+SpringSecurity+MybatisPlus实现Restful鉴权脚手架
若图片查看异常,请前往掘金查看:https://juejin.im/post/5d1dee34e51d4577790c1cf4 前言 JWT(json web token)的无状态鉴权方式,越来越流行 ...
- PAT T1011 Cut Rectangles
大模拟题,按要求建立多边形,先定位斜边的位置,再分类讨论~ #include<bits/stdc++.h> using namespace std; ; struct node { dou ...
- Django中的prefetch_related()函数优化
对于多对多字段(ManyToManyField)和一对多字段, 可以使用prefetch_related()来进行优化 prefetch_related()和select_related()的设计目的 ...
- Java 自定义DateUtils
1 /* Date d = new Date(); String s = DateUtils.DateToString(d, "yyyy-MM-dd HH:mm:ss"); Sys ...
- 树莓派4B踩坑指南 - (3)无显示器连接
无显示器连接 WiFi:如果是原装系统,直接修改wpa_supplicant.conf文件后,放入boot即可(一定注意ssid名称不要写错!!惨痛教训T^T) SSH:在boot盘下新建一个 SSH ...
- JS - false 的 六种类型
document.write("--------------");document.write(!false);document.write("------------- ...
- request和response对象如何解决中文乱码问题?
出现中文乱码的问题,一般的原因编码和和解码不一致造成的. /* 乱码:编码和解码不一致导致的 GET:你好 POST:?????? tomcat版本:8.5及以上版本 GET请求方式,request对 ...
- 【项目】小试牛刀-polo360静态网页项目(附psd文件资源)
笔者尝试下开发简单的静态网页,下面分享过程及源码.这是polo360的下载链接:https://pan.baidu.com/s/1WqGxKMYY_DHfrSJ9lLL-WA 提取码:v2qi (一 ...
- XML简单介绍
什么是 XML? XML 指可扩展标记语言(EXtensible Markup Language). XML 是一种很像HTML的标记语言. XML 的设计宗旨是传输数据,而不是显示数据. XML 标 ...