[CSP-S模拟测试]:666(模拟)
题目描述
不忘初心。
小$\pi$假期在家无聊,打开了某弹幕直播网站。
突然,有一个精彩的镜头。
小$\pi$看到了满屏的$6$,其中,有$666$、也有$666666$、也有$6666666666...$
小$\pi$也想发个弹幕,他打算发$n$个$6$。
然而当他按下第一个$6$时,键盘上$6$的键坏了。
这时,弹幕框里只有$1$个$6$。
键盘坏了什么的不要紧,先把弹幕发了才是正事。
于是小$\pi$打算用复制粘贴这类操作来生成这$n$个$6$。
具体的说,小$\pi$电脑的操作系统有唯一的一块剪贴板,初始为空,现在小
$\pi$一共有三种操作:
第$1$种操作,全选然后复制。这样会把剪贴板里的内容设置为当前弹幕框内内容。
第$2$种操作,粘贴。会把剪贴板中的内容连接到弹幕框现有的内容后面。
第$3$种操作,$backspace$。会把在当前弹幕框中删除一个$6$。
小$\pi$很好奇现在生成想要的$n$个$6$至少需要多少次操作,来找到了学信息学竞赛的你。
注意本题时间限制
输入格式
一行一个整数$n$。
输出格式
一行一个整数$ans$,表示最少操作次数。
样例
样例输入1:
0
样例输出1:
1
样例输入2:
3
样例输出2:
3
数据范围与提示
其中$6\%$的数据,$n=2^k$,$k$为正整数。
其中$24\%$的数据,$n\leqslant 1,000$。
其中$20\%$的数据,内存扩充至$768MB$。
其中$20\%$的数据,时间扩充到$3s$。
其中$30\%$的数据,无特殊限制。
所有数据存在一种划分方法,使得上述范围两两没有交集。
对于$100\%$的数据,$0\leqslant n\leqslant 1,000,000$。
题解
模拟全过程。
设$f[i]$表示$i$个$6$的步数,初始时将其都付成没有访问过,$f[1]=0$。
然后每次暴力扫,用现在有的更新即可。
因为最多会走$48$步,所以时间复杂度是对的。
时间复杂度:$\Theta(48\times n)$。
期望得分:$100$分。
实际得分:$100$分。
代码时刻
#include<bits/stdc++.h>
int n,dp[1000100],bs;
int main()
{
scanf("%d",&n);
memset(dp,-1,sizeof(dp));
dp[1]=0;int now=n+50;
while(dp[n]==-1)
{
bs++;
for(register int i=1;i<=now;i++)
{
if(dp[i]==-1)continue;
register int flag=i*(bs-dp[i]);
if(flag<=now&&dp[i]<bs&&dp[flag]==-1)dp[flag]=bs;
if(dp[i-1]==-1)dp[i-1]=dp[i]+1;
}
}
printf("%d",dp[n]);
return 0;
}
rp++
[CSP-S模拟测试]:666(模拟)的更多相关文章
- 模拟测试—moq:简单一两句
在Xunit的基础上,说话模拟测试. 假如我们有这样一个控制器里面有这样一个方法,如图 我们在对Bar测试得时候,如果测试未通过,错误有可能来至于Bar,也有可能错误来至于serverde Foo方法 ...
- csp-s模拟测试89
csp-s模拟测试89 $T1$想了一会儿没什么思路,一看$T2$ $1e18$当场自闭打完暴力就弃了,$T3$看完题感觉要求$lca$和$dep$,手玩了一下样例发现$lca$很显然,$dep$貌 ...
- Android单元测试与模拟测试详解
测试与基本规范 为什么需要测试? 为了稳定性,能够明确的了解是否正确的完成开发. 更加易于维护,能够在修改代码后保证功能不被破坏. 集成一些工具,规范开发规范,使得代码更加稳定( 如通过 phabri ...
- [开源]微信在线信息模拟测试工具(基于Senparc.Weixin.MP开发)
目前为止似乎还没有看到过Web版的普通消息测试工具(除了官方针对高级接口的),现有的一些桌面版的几个测试工具也都是使用XML直接请求,非常不友好,我们来尝试做一个“面向对象”操作的测试工具. 测试工具 ...
- 安装nginx python uwsgi环境 以及模拟测试
uwsgi帮助文档: http://uwsgi-docs-cn.readthedocs.io/zh_CN/latest/WSGIquickstart.html http://uwsgi-docs.re ...
- 利用Python中的mock库对Python代码进行模拟测试
这篇文章主要介绍了利用Python中的mock库对Python代码进行模拟测试,mock库自从Python3.3依赖成为了Python的内置库,本文也等于介绍了该库的用法,需要的朋友可以参考下 ...
- 转 C#实现PID控制的模拟测试和曲线绘图
C#实现PID控制的模拟测试和曲线绘图 本文分两部分,一部分是讲PID算法的实现,另一部分是讲如何用动态的曲线绘制出PID运算的结果. 首先,PID算法的理论模型请参考自动控制理论,最早出现的是模 ...
- Mockito:一个强大的用于Java开发的模拟测试框架
https://blog.csdn.net/zhoudaxia/article/details/33056093 介绍 本文将介绍模拟测试框架Mockito的一些基础概念, 介绍该框架的优点,讲解应用 ...
- NOIP模拟测试1(2017081501)
好,今天是cgg第一次举行模拟测试,希望各位支持. 时间限制:2小时 题目链接: 题目一:水得都没名字了 题目二:车站 题目三:选数 不要觉得2小时太少,我的题目很良心,都很简单. 答案可以在模拟测试 ...
随机推荐
- 克隆完虚拟机后修改网卡,修改静态IP
命令:vim /etc/sysconfg/network-scripts/ifcfg-eth0 编辑: vi /etc/udev/rules.d/70-persistent-net.rules 克隆 ...
- [BZOJ2144][国家集训队2011]跳跳棋
题目描述 跳跳棋是在一条数轴上进行的.棋子只能摆在整点上. 每个点不能摆超过一个棋子. 我们用跳跳棋来做一个简单的游戏:棋盘上有3颗棋子,分别在\(a\),\(b\),\(c\)这三个位置. 我们要通 ...
- Quartz的job中注入的services接口为空的解决办法
自己重新定义一个类继承AdaptableJobFactory类 public class JobFactory extends AdaptableJobFactory { @Autowired pri ...
- limux密钥对配置登陆主机
1. Linux主机免密码使用密钥登陆 这里假设主机A(192.168.0.113)用来远程连接主机B(192.168.0.186) 在主机A上执行如下命令来生成配对密钥:ssh-keygen -t ...
- 如何使用Resource资源文件
一.目的 为了能够在DisplayAttribute中重复使用同样的名称,将所有的显示字符串集中管理. 二.方法 1.DisplayAttribute本身支持直接使用资源文件. [Display(Re ...
- 一分钟理解sdk
SDK 外语:Software Development Kit 中文:软件开发工具包 含义:一般都是一些软件工程师为特定的软件包.软件框架.硬件平台.操作系统等建立应用软件时的开发工具的集合. 通俗: ...
- django 实现 Mock Server
大佬 flask 实现mock server地址:https://github.com/yinquanwang/MockServer 参考使用django实现了一下,并已部署到EasyTest测试平台 ...
- git如何忽略特殊文件
有些时候,你必须把某些文件放到Git工作目录中,但又不能提交它们,比如保存了数据库密码的配置文件啦,等等,每次git status都会显示Untracked files ...,有强迫症的童鞋心里肯定 ...
- laravel 的lnmp 的配置
装了lnmp后,一般用 lnmp vhost add 添加网站 一般 只用重写和ssl功能 再发laravel官方的配置 server { listen 80; server_name example ...
- [转载]MII/MDIO接口详解
原文地址:MII/MDIO接口详解作者:心田麦浪 本文主要分析MII/RMII/SMII,以及GMII/RGMII/SGMII接口的信号定义,及相关知识,同时本文也对RJ-45接口进行了总结,分析了在 ...