B1091 N-自守数 (15分)
B1091 N-自守数 (15分)
如果某个数 \(K\)的平方乘以\(N\) 以后,结果的末尾几位数等于 \(K\),那么就称这个数为“\(N\)-自守数”。例如 \(3×92
^2
=25392\),而 25392 的末尾两位正好是 92,所以 92 是一个 3-自守数。
本题就请你编写程序判断一个给定的数字是否关于某个 N 是 N-自守数。
输入格式:
输入在第一行中给出正整数 \(M(≤20)\),随后一行给出 \(M\) 个待检测的、不超过 1000 的正整数。
输出格式:
对每个需要检测的数字,如果它是 \(N\)-自守数就在一行中输出最小的 $N $和 \(NK
^2\)
的值,以一个空格隔开;否则输出 No
。注意题目保证 \(N<10\)。
输入样例:
3
92 5 233
输出样例:
3 25392
1 25
No
思路
对0-9逐一检验
9000000
为什么我的代码有一个测试点过不去。
因为对0所有数都会自守的,对一些特殊的数要特别看待。
#include<bits/stdc++.h>
using namespace std;
int tmp_ans[9];
int ans[9];
int change(int a[],int b){
int num = 0;
while(b!=0){
a[num++]=b%10;
b/=10;
}
return num;
}
int main(void){
int m,tmp,tmp_num,num,true_ans;
int flag;
scanf("%d",&m);
getchar();
for(int i=0;i<m;i++){//对每个数都处理一次标记
flag = -1;
scanf("%d", &tmp);//要判断有几位数,最大是4位
tmp_num=change(tmp_ans,tmp);
for(int j=0;j<10;j++){
flag = -1;
true_ans=tmp*tmp*j;
num=change(ans,true_ans);
for(int k=0;k<tmp_num;k++){
if(ans[k]!=tmp_ans[k]){
flag = k;
break;
}
}
if(flag==-1){
printf("%d %d\n",j,true_ans);
break;
}
}
if(flag!=-1)
printf("No\n");/*无自守数*/
}
return 0;
}
AC代码
/*消去0这个自守。*/
for(int j=1;j<10;j++)
来自别人的AC代码
不是暴力而是数学的写法。
作者:dk_qi
链接:https://www.jianshu.com/p/c59448ce5414
以题中\(3×92^2=25392\)为例,当数\(K\)为\(92\),自守数\(N\)为\(3\)时,有
(3×92×92-92)% 100 = 0
推广即得
(NKK-K) % ( 10 ^ {length( K ) } ) = 0
#include<stdio.h>
int len(int K); //该函数返回10的K的长度次方。
int main()
{
int M, K, l, flag;
scanf("%d", &M);
for(int i = 0; i < M; i++){
scanf("%d", &K);
l = len(K);
flag = 0; // flag标记K是否有自守数
for(int j = 0; j < 10; j++){
if((j * K * K - K) % l == 0){
printf("%d %d\n", j, j*K*K);
flag = 1;
break; //得到最小自守数后直接break
}
}
if(flag == 0) printf("No\n");
}
return 0;
}
int len(int K){
int len = 1;
while(K){
len *= 10;
K /= 10;
}
return len;
}
B1091 N-自守数 (15分)的更多相关文章
- PAT Basic 1091 N-自守数 (15 分)
如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为“N-自守数”.例如 3,而 2 的末尾两位正好是 9,所以 9 是一个 3-自守数. 本题就请你编写程序判断一个给定的 ...
- 1091 N-自守数 (15 分)C语言
如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为"N-自守数".例如 3×92^2 =25392,而 25392 的末尾两位正好是 92,所以 ...
- Day 001:PAT练习--1091 N-自守数 (15 分)
体验了一阵子现代生活后,朕发现敲代码还是挺有意思的.所以从今天开始,小编秦始皇开始记录朕做PAT题目的过程辣,那话不多说,开始今天的题目了: 题目描述: 如果某个数 K 的平方乘以 N 以后, ...
- 1091 N-自守数 (15 分)
// 建一个判断函数,接受两个整形的变量,再通过循环按位判断相等与否,主体函数中调用被调函数,建立一个判断变量.#include <iostream> using namespace st ...
- P1091 N-自守数
1091 N-自守数 (15分) 如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为“N-自守数”.例如 3,而 2 的末尾两位正好是 9,所以 9 是一个 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-自守 ...
- PAT B1091 N-自守数
输入样例: 3 92 5 233 输出样例: 3 25392 1 25 No '解题思路:判断的时候将结果转换成字符串,判断后面几位数字和输入数字是否相同,掉进了N是从1到10的坑,而不是1到9 ...
随机推荐
- jquery 根据日期计算年龄
<script type="text/javascript"> //jquery页面加载完成后,根据后端的出生日期,计算年龄 $(function () { // 获得 ...
- cf914D. Bash and a Tough Math Puzzle(线段树)
题意 题目链接 Sol 直接在线段树上二分 当左右儿子中的一个不是\(x\)的倍数就继续递归 由于最多递归到一个叶子节点,所以复杂度是对的 开始时在纠结如果一段区间全是\(x\)的两倍是不是需要特判, ...
- position 的属性值
理论上来说,全部 position 的取值有8个 包括:position:static | relative | absolute | fixed | sticky | initial | inhe ...
- vue组件双向绑定.sync修饰符的一个坑
我们知道组件是单项的,但是有时候需要双向,这时候我们可以使用.sync修饰符,但今天遇到一个坑,一直不成功,花了半小时试出来的.... 在编程的时候我们很习惯冒号后面跟着空格.而.sync双向绑定需要 ...
- 画布canvas签名
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...
- iOS沙盒(sandbox)机制及获取沙盒路径
一.每个iOS应用SDK都被限制在沙盒中,沙盒相当于一个加了仅主人可见权限的文件夹,苹果对沙盒有以下几条限制. (1).应用程序可以在自己的沙盒里运作,但是不能访问任何其他应用程序的沙盒. (2).应 ...
- C++基础--sizeof和strlen的区别
首先,来运行一段程序: #include "stdafx.h" #include <stdio.h> #include <string.h> int mai ...
- ASP.NET Core - 初期准备
微软在前不久发布了.NET Core1.0(以下简称Core),由于项目需要开始对其进行研究,希望将自己踩过的坑和见解分享给大家. Core和Framework4.6是属于并行产品,前者侧重于跨平台的 ...
- 【JavaScript 封装库】BETA 2.0 测试版发布!
/* 源码作者: 石不易(Louis Shi) 联系方式: http://www.shibuyi.net =============================================== ...
- Poj(2236),简单并查集
题目链接:http://poj.org/problem?id=2236 思路很简单,傻逼的我输出写成了FALL,然后遍历的时候for循环写错了,还好很快我就Debug出来了. #include < ...