纪中5日T3 1566. 幸运锁(lucky.pas/c/cpp)
1566. 幸运锁(lucky.pas/c/cpp)
题目描述
有一把幸运锁,打开它将会给你带来好运,但开锁时需要输入一个正整数(没有前导0)。幸运锁有一种运算,对于一个正整数,返回他的相邻两位数字间的差,如1135,运算结果为22(会去掉前导0)。
现在已知只有经过反复运算最终结果为7的数才能打开这把锁,给你一个区间[a,b],问该区间中有多少个能打开幸运锁的幸运数。
输入
第一行两个整数a,b。
输出
一个整数K,表示共有多少个这样的数。
样例输入
1 10
样例输出
1
数据范围限制
【限制】
1<=a<=b<=10^9。
30%的数据有b<=10^6。
Solution(28分)

貌似正好遇上服务器出问题了呢
这就不是我的问题了
(这也不是服务器的问题嘛!你怎么可以这样想呢?)
我觉得我的代码是正确的
而测试点2呢,我用一个打表的程序也过了
table
首先奉上我的table.cpp
//幸运锁表
#include<bits/stdc++.h>
using namespace std;
int n,m,a,b,lucky,h,f[],ans;
int logn(int num)
{
if(num==) return ;
return log(num)/;
}
void fj(int num)
{
int len=logn(num);
for(int i=;i<len;i++)
{
f[i]=((int)(num/pow(,i)))%;
}
return;
}
void run(int num[],int len)
{
// 检测是否为0000000..7||0000000..*
bool flag7=;
for(int i=;i<len;i++)
if(num[i]!=) {
flag7=;
break;
} if(flag7)
{
if(num[]==)
{
cout<<h<<",";
ans++;
} return;
} // 算差
int w[len];
memset(w,,sizeof(w));
for(int i=;i<len-;i++)
w[i]=abs(num[i]-num[i+]);
// 删除前导零
int flag0=;
for(int i=len-;i>=;i--)
{
if(flag0)
{
if(num[i]==)
len--;
else
flag0=;
}
else
break;
}
run(w,len-);
}
int main()
{
// freopen("lucky.in","r",stdin);
// freopen("lucky表.txt","w",stdout);
for(h=;h<=;h++)
{
//分解数字
fj(h);
run(f,logn(h));
}
cout<<"\nans="<<ans;
return ;
}
想要过程解释,还请看注释。
正解会再做详细解释。
这个cpp可以打出从a~b所有满足条件的数
但我并没有找到什么规律鸭
Code(46分)
//幸运锁
#include<bits/stdc++.h>
using namespace std;
int n,m,a,b,lucky,f[],ans;
int logn(int num)
{
if(num==) return ;//本来log(1)会等于0的
return log(num)/;
}
void fj(int num)
{
int len=logn(num);
for(int i=;i<len;i++)
{
f[i]=((int)(num/pow(,i)))%;
}
return;
}
void run(int num[],int len)
{
// 检测是否为0000000..7||0000000..*
bool flag7=;
for(int i=;i<len;i++)
if(num[i]!=) {
flag7=;
break;
}
//如果flag7==1,就说明该数只有个位了,其他位全是零
if(flag7)
{
if(num[]==)
ans++;
return;//一个位数是一定不能变成7的
}
// 算差
int w[len];
memset(w,,sizeof(w));//开始时忘了初始化,坑了我好久
for(int i=;i<len-;i++)
w[i]=abs(num[i]-num[i+]);//相邻两数之差要取绝对值
// 删除前导零
int flag0=;
for(int i=len-;i>=;i--)
{
if(flag0)
{
if(num[i]==)
len--;
else
flag0=;
}
else
break; }
run(w,len-);//就是这里! 求差后,len一定会自然的少一个
}
int main()
{
// freopen("lucky.in","r",stdin);
// freopen("lucky.out","w",stdout);
cin>>a>>b;
for(int i=a;i<=b;i++)
{
//分解数字
fj(i);
run(f,logn(i));
}
cout<<ans; return ;
}
修改了这个地方后,成功的又对了一个测试点。

下载一个数据看看?
File Not Found!
额
老师呢,看了看那些100分的同学的代码。
大小都是几MB几MB的。
又因为我是时间超限……
你明白了吗?
打表!
那个。。。源代码太长,我我我上传不了。
就先发个压缩包吧
https://files-cdn.cnblogs.com/files/send-off-a-friend/lucky.rar
数论
等待着数论的方法出现。。。
老师加油!
纪中5日T3 1566. 幸运锁(lucky.pas/c/cpp)的更多相关文章
- 纪中21日T3 2118. 【2016-12-30普及组模拟】最大公约数
纪中21日T3 2118. 最大公约数 (File IO): input:gcd.in output:gcd.out 时间限制: 1000 ms 空间限制: 262144 KB 具体限制 Goto ...
- 纪中10日T3 2296. 神殿 bfs
2296. 神殿 (File IO): input:temple.in output:temple.out 时间限制: 1500 ms 空间限制: 524288 KB 具体限制 Goto Prob ...
- 纪中17日T1 2321. 方程
纪中17日T1 2321. 方程 (File IO): input:cti.in output:cti.out 时间限制: 1000 ms 空间限制: 262144 KB 具体限制 Goto ...
- 纪中10日T1 2313. 动态仙人掌
纪中10日 2313. 动态仙人掌 (File IO): input:dinosaur.in output:dinosaur.out 时间限制: 1500 ms 空间限制: 524288 KB 具 ...
- 纪中23日c组T3 2161. 【2017.7.11普及】围攻 斐波那契数列
2161. 围攻 (File IO): input:siege.in output:siege.out 时间限制: 1000 ms 空间限制: 262144 KB 具体限制 Goto Prob ...
- 纪中23日c组T2 2159. 【2017.7.11普及】max 洛谷P1249 最大乘积
纪中2159. max 洛谷P1249 最大乘积 说明:这两题基本完全相同,故放在一起写题解 纪中2159. max (File IO): input:max.in output:max.out 时间 ...
- 洛谷P1880 [NOI1995]石子合并 纪中21日c组T4 2119. 【2016-12-30普及组模拟】环状石子归并
洛谷P1880 石子合并 纪中2119. 环状石子归并 洛谷传送门 题目描述1 在一个圆形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆合并成新的一堆,并将新的一堆的石 ...
- 纪中20日c组T2 2122. 【2016-12-31普及组模拟】幸运票
2122. 幸运票 (File IO): input:tickets.in output:tickets.out 时间限制: 1000 ms 空间限制: 262144 KB 具体限制 Goto P ...
- 纪中18日c组模拟赛
T2 GMOJ2127. 电子表格 (File IO): input:excel.in output:excel.out 时间限制: 1000 ms 空间限制: 262144 KB 具体限制 ...
随机推荐
- Jmeter——使用JSR223元件实现RSA登录加密
一.RSA加密简介 RSA加密是一种非对称加密.可以在不直接传递密钥的情况下,完成解密.这能够确保信息的安全性,避免了直接传递密钥所造成的被破解的风险.是由一对密钥来进行加解密的过程,分别称为公钥和私 ...
- win10系统安装VMware虚拟机软件以及linux系统
一.安装VMware 1.在VMware官网下载VMware Workstation Pro 15.5.1 下载地址:https://my.vmware.com/cn/web/vmware/detai ...
- 基于原生的 html css js php ajax做的一个 web登录和注册系统
完整代码下载: 百度网盘地址 https://pan.baidu.com/s/1D1gqHSyjgfoOtYCZm7ofJg 提取码 :nf0b 永久有效 注意: 1 如果要正常运行此示例, 本地需要 ...
- 动态获取bind dns日志IP脚本
#!/usr/bin/env python #_*_coding:utf-8_*_ ''' python deny_dns_allip.py your_filelog_name 动态获取dns日志的I ...
- raid知识梳理及其详细介绍
1 raid级别 生产环境常用到的raid级别有raid0,raid1,raid5,raid10.所以侧重学习这几种raid级别即可. 1.1 raid0条带卷 raid0示意图: raid0特点介绍 ...
- 2020 年 中国.NET开发者调查报告
微信公众号dotnet跨平台2020年初做的一个关于中国.NET开发者调查收到了开发者近 1400 条回复.这份调查报告涵盖了开发者工具链的所有部分,包括编程语言.应用架构.应用服务器.运行时平台.框 ...
- Element-UI ( Dropdow )下拉菜单组件command传输对象
通过 :command绑定对象数据,handleCommand方法处理数据 template <div v-for="(item, index) in FlyWarningList&q ...
- 【WPF学习】第四十九章 基本动画
在前一章已经学习过WPF动画的第一条规则——每个动画依赖于一个依赖项属性.然而,还有另一个限制.为了实现属性的动态化(换句话说,使用基于时间的方式改变属性的值),需要有支持相应数据类型的动画类.例如, ...
- [javascript] test() 方法进行正则验证
test() 方法用于检测一个字符串是否匹配某个模式 最近遇到的某业务中进行发票抬头的正则验证如下: console.log(/^[a-zA-Z\u4e00-\u9fa5\s()()<>& ...
- mysql简单备份与恢复
1.备份 mysqldump -u root -h 127.0.0.1 -p --set-gtid-purged=OFF abc > /data/mysqlBak/abc_20200206.s ...