【数位统计】之【spoj1433 KPSUM】
【spoj1433】KPSUM
来源
高逸涵《数位计数问题解法研究》
由于自己的数位计数类的问题实在太差了,所以把例2用markdown抄写并补充了一遍。
题意
将写在纸上,然后在相邻的数字间交替插入“+”和“-”,求最后的结果。例如当时,答案为:
分析
这是一道稍微复杂一点的数位计数问题。
我们首先探查数位确定,所有数字自由的情况。
不妨设第一位从”+”开始。
若数位个数为偶数,以6位为例:
| +0 | -0 | +0 | -0 | +0 | -0 |
| +0 | -0 | +0 | -0 | +0 | -1 |
| +0 | -0 | +0 | -0 | +0 | -2 |
| … | … | … | … | … | … |
| +9 | -9 | +9 | -9 | +9 | -9 |
发现:
①每个数位的符号相同,奇数符号的数位和偶数符号的数位个数相等。
②每个数位中每个数出现的次数相同。
所有数位的所有数的和为0。
若数位个数为奇数,以5位为例:
| +0 | -0 | +0 | -0 | +0 |
| -0 | +0 | -0 | +0 | -1 |
| +0 | -0 | +0 | -0 | +2 |
| -0 | +0 | -0 | +0 | -3 |
| … | … | … | … | … |
| +9 | -9 | +9 | -9 | +8 |
| -9 | +9 | -9 | +9 | -9 |
相邻两行的和为-1。
之前我们这样认定:
不妨设第一位从”+”开始。
然而第一位不一定是+,这跟总位数有关。
注意:当前我们考虑的只是后面位对答案的贡献,前缀对答案的贡献并没有计算。
(1)当为偶数时
①当为偶数时,后面位数的贡献为0;
②当为奇数时,从第位开始贡献为0,所以我们只需要考虑第位的贡献。
第位的全是负号,贡献为:
(2)当为奇数时,相邻两行和为-1,总共有个数,所以有行,所以贡献为:
于是我们写出函数GetSum1。
LL GetSum1(int n,int k)
//n为自由位个数,k为总位数
{
if (k%2==0)
{
if (n%2==0) return 0;
else
{
LL d=-45;
rep(i,1,n-1) d*=10;
return d;
}
}
else
{
LL d=-1;
rep(i,1,n) d*=10;
return d/2;
}
}
接下来,考虑带前缀的情况。总位数=前缀位+自由位。
(1)当总位数为偶数时,前缀符号不变,乘上总行数即可。
(2)当总位数为奇数时,前缀两两相消。
依照以上分析编写GetSum2。
LL GetSum2(LL prefix,int n)
//prefix为前缀,n为自由位个数
{
int d=0,t=1;
LL p=prefix,presum=0;
while (p>0)
{
presum+=(p%10)*t;
p/=10;
d++;
t=-t;
}
presum*=-t;
rep(i,1,n) presum*=10;
LL ret=GetSum1(n,n+d);
if ((d+n)%2==0) ret+=presum;
return ret;
}
沿用上例的思路,,再有了上述两个函数之后,我们继续将整个区间划分为若干段,分别利用上述函数求和,这里不再重复叙述。
小结
通过对问题从简单到复杂的层层递进分析,逐步将程序实现,使得一个原本比较复杂的问题轻松被解决。程序编写过程中思路明确,程序模块化合理,每个模块功能明确,并且单独可以通过check函数进行检验。使得出错的可能性大大降低。
虽然整体代码量有所增加,但由于思考的时间减少,代码编写时间甚至还会缩短。
【数位统计】之【spoj1433 KPSUM】的更多相关文章
- Codeforces 55D Beautiful Number (数位统计)
把数位dp写成记忆化搜索的形式,方法很赞,代码量少了很多. 下面为转载内容: a positive integer number is beautiful if and only if it is ...
- [ACM] ural 1057 Amount of degrees (数位统计)
1057. Amount of Degrees Time limit: 1.0 second Memory limit: 64 MB Create a code to determine the am ...
- 动态规划——区间DP,计数类DP,数位统计DP
本博客部分内容参考:<算法竞赛进阶指南> 一.区间DP 划重点: 以前所学过的线性DP一般从初始状态开始,沿着阶段的扩张向某个方向递推,直至计算出目标状态. 区间DP也属于线性DP的一种, ...
- BZOJ 1236: SPOJ1433 KPSUM
Description 用+-号连接1-n所有数字的数位,问结果是多少. Sol 数位DP. \(f[i][j][0/1][0/1]\) 表示长度为 \(i\) 的数字,开头数字是 \(j\) ,是否 ...
- 数位DP:SPOJ KPSUM - The Sum
KPSUM - The Sum One of your friends wrote numbers 1, 2, 3, ..., N on the sheet of paper. After that ...
- 0x5C 数位统计DP
怎么说,数位DP还是我的噩梦啊,细节太恐怖了. 但是这章感觉又和之前的学的数位DP有差异?(应该是用DP预处理降低时间复杂度,好劲啊,不过以前都是记忆化搜索的应该不会差多少) poj3208 f[i] ...
- 紫书 例题 10-22 UVa 1640(数位统计)
这道题的题解有几个亮点 一个是每次只统计一个数字来简化思维 一个是统计当前位数的时候分三个部分来更新答案 具体看代码,有注释 #include<cstdio> #include<cs ...
- $BZOJ1799\ Luogu4127$ 月之谜 数位统计$DP$
AcWing Description Sol 看了很久也没有完全理解直接$DP$的做法,然后发现了记搜的做法,觉得好棒! 这里是超棒的数位$DP$的记搜做法总结 看完仿佛就觉得自己入门了,但是就像 ...
- $Poj3208$ 启示录 数位统计$DP$
Poj AcWing Description Sol 这题长得就比较像数位$DP$叭. 所以先用$DP$进行预处理,再基于拼凑思想,通过"试填法"求出最终的答案. 设$F[i] ...
随机推荐
- 数据库连接池系列之——c3p0
c3p0的jar包是:c3p0-0.9.1.jar <bean id = "dataSource" class = "com.mchange.v2.c3p0.Com ...
- 【Java】Float计算不准确
大家可能都遇到过,float在计算某些值时,会有不准确的情况. 比如如下情况: > 计算不准确 package com.nicchagil.study.java.demo.No10float计算 ...
- Linux企业运维高效技巧心得及分享
本博文出自51CTO博主 吴光科 的博客,有任何问题请进入博主页面互动讨论! 博文地址:http://wgkgood.blog.51cto.com/1192594/1641247 随着Linux在企业 ...
- Android 路径大全
1 内部存储路径为/data/data/youPackageName/ 目录结构 //返回cache文件对象 this.getCacheDir(); //返回databases下指定文件 this.g ...
- Windows下通过bat脚本实现自动上传文件到ftp服务器
@Echo Off Echo open ip_address [port] >ftp.up Echo [username]>>ftp.up Echo [password]>&g ...
- Linux 在一个命令行上执行多个命令
Linux 在一个命令行上执行多个命令 1. [ ; ] 如果被分号(;)所分隔的命令会连续的执行下去,就算是错误的命令也会继续执行后面的命令. 2. [ && ] 如果命令被 &am ...
- 深度信任网络的快速学习算法(Hinton的论文)
也没啥原创,就是在学习深度学习的过程中丰富一下我的博客,嘿嘿. 不喜勿喷! Hinton是深度学习方面的大牛,跟着大牛走一般不会错吧-- 来源:A fast learning algorithm fo ...
- 在Yii用createUrl中明明白白生成网址
在Yii中经常要生成URL,不管是为了自动跳转还是仅仅是一个链接.下面对Yii中的URL生成做了一个总结.提示:以下controllerX代表控制器X,actionX代表方法X.在Controller ...
- [转发] 理解 oauth 2.0
原文: http://www.ruanyifeng.com/blog/2014/05/oauth_2_0.html oauth 的各种编程语言实现: http://oauth.net/2/ 理解OAu ...
- [转载] C++ 程序员快过来围观:非常实用全面的 C++ 资源
原文: http://codecloud.net/c-plus-plus-resource-2983.html 绝对是c++开发者的福音啊, 必须推荐. 这次的资源涉及到了标准库.Web应用框架.人工 ...