BZOJ 1236: SPOJ1433 KPSUM
Description
用+-号连接1-n所有数字的数位,问结果是多少.
Sol
数位DP.
\(f[i][j][0/1][0/1]\) 表示长度为 \(i\) 的数字,开头数字是 \(j\) ,是否有前导0(这个会影响符号),每相邻两组数符号是否相同.
转移开一下代码吧.
这道题的符号有点乱,所以转移看起来有些乱...其实只有3个状态,没前导0,有前导0相邻两个数符号相同,有前导0相邻两个数符号不同.
没前导0的只有在第一次统计才会用到.
我发现自己写数位DP就是写小于 \(n\) 的,所有都需要将 \(n+1\) 计算...
一开始自己神tm的取了模...
Code
/**************************************************************
Problem: 1236
User: BeiYu
Language: C++
Result: Accepted
Time:0 ms
Memory:1308 kb
****************************************************************/ #include <cstdio>
#include <iostream>
using namespace std; #define debug(a) cout<<#a<<"="<<a<<" " typedef long long LL;
const int N = 25; LL n;
LL f[N][N][2][2];// i,j 0/1 qiandao0 0/1 fuhao
LL pow10[N]; void init() {
pow10[0]=1;
for(int i=1;i<=18;i++) pow10[i]=pow10[i-1]*10;
for(int j=0;j<10;j++) {
f[1][j][0][0]=f[1][j-1][0][0]+(j&1 ? 1 : -1)*j;
f[1][j][1][0]=f[1][j][0][0];
f[1][j][1][1]=f[1][j-1][1][1]-j;
}
for(int i=2;i<=18;i++) {
f[i][0][0][0]=f[i-1][9][0][0];
f[i][0][1][0]=-f[i-1][9][1][0];
f[i][0][1][1]=-f[i-1][9][1][1];
for(int j=1;j<10;j++) {
f[i][j][0][0]=f[i][j-1][0][0]-f[i-1][9][1][!(i&1)]-(!(i&1))*j*pow10[i-1];
f[i][j][1][0]=f[i][j-1][1][0]-f[i-1][9][1][0];
f[i][j][1][1]=f[i][j-1][1][1]-f[i-1][9][1][1]-j*pow10[i-1];
}
} /* for(int i=1;i<=3;i++) {
for(int j=0;j<10;j++) {
cout<<i<<" "<<j<<":\n";
for(int p=0;p<2;p++) for(int q=0;q<2;q++) debug(f[i][j][p][q]);
cout<<endl;
}
}*/
}
LL calc(LL x) {
LL g=0,r=0,v=0;
for(int i=18;i;i--) {
if(x/pow10[i-1]) {
if(!g) {
r+=f[i][x/pow10[i-1]-1][0][0];
g=i;
}else {
r+=f[i][x/pow10[i-1]-1][1][!(g&1)]*((g-i)&1 ? -1 : 1);
}
if(g&1){
if((x%pow10[i-1])&1) r+=x/pow10[i-1]*((g-i)&1 ? 1 : -1);
}else {
r+=x/pow10[i-1]*(x%pow10[i-1])*((g-i)&1 ? 1 : -1);
}
}x%=pow10[i-1];
}return r;
}
int main() {
init();
cin>>n;
cout<<calc(n+1)<<endl;
// while(cin>>n) cout<<calc(n+1)<<endl;
return 0;
}
BZOJ 1236: SPOJ1433 KPSUM的更多相关文章
- 【数位统计】之【spoj1433 KPSUM】
[spoj1433]KPSUM 来源 高逸涵<数位计数问题解法研究> 由于自己的数位计数类的问题实在太差了,所以把例2用markdown抄写并补充了一遍. 题意 将写在纸上,然后在相邻的数 ...
- bzoj 1236: longpo的回文
1236: longpo的回文 题目描述 一个字符串如果从左到右和从右到左读的结果是一样的,我们称之为回文串.现在给定一个字符串,我们有三种操作: 1. 添加一个字母在任何位置(可以在首尾添加 ...
- spoj1433 KPSUM
题意:略: 首先知道10,20,......100,200,1000的前面的符号都是负号. 举具体例子:221时,计算过程为 000-009, 010-019, 020-029...... ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- 【BZOJ】【1269】【AHOI2006】文本编辑器editor
Splay Splay序列维护的模板题了……为了便于处理边界情况,我们可以先插入两个空格当作最左端和最右端,然后……其实本题主要考察的就是Build.splay和Findkth这三个操作,我们可以实现 ...
- 【BZOJ】【2179】FFT快速傅里叶
FFT 做的第二道用到FFT的……好吧其实还是模板题-_-b 百度上说好像分治也能做……不过像FFT这种敲模板的还是省事=.= /*********************************** ...
- BZOJ 2127: happiness [最小割]
2127: happiness Time Limit: 51 Sec Memory Limit: 259 MBSubmit: 1815 Solved: 878[Submit][Status][Di ...
- BZOJ 3275: Number
3275: Number Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 874 Solved: 371[Submit][Status][Discus ...
- BZOJ 2879: [Noi2012]美食节
2879: [Noi2012]美食节 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1834 Solved: 969[Submit][Status] ...
随机推荐
- [LeetCode] Moving Average from Data Stream 从数据流中移动平均值
Given a stream of integers and a window size, calculate the moving average of all integers in the sl ...
- [LeetCode] Linked List Cycle II 单链表中的环之二
Given a linked list, return the node where the cycle begins. If there is no cycle, return null. Foll ...
- 记一次企业级爬虫系统升级改造(二):基于AngleSharp实现的抓取服务
爬虫系统升级改造正式启动: 在第一篇文章,博主主要介绍了本次改造的爬虫系统的业务背景与全局规划构思: 未来Support云系统,不仅仅是爬虫系统,是集爬取数据.数据建模处理统计分析.支持全文检索资源库 ...
- 自动化运维工具ansible部署以及使用
测试环境master 192.168.16.74webserver1 192.168.16.70webserver2 192.168.16.72安装ansiblerpm -Uvh http://ftp ...
- SQL Server 2012附加数据库时,错误提示如下:尝试打开或创建物理时,CREATE FILE 遇到操作系统错误 5(拒绝访问。)
错误提示:Create File遇到操作系统错误5(拒绝访问) 解决方案: 在所有程序-SQL Server 2012-"SQL Server 配置管理器",点击"SQL ...
- 【MySQL】mysql workbench
1.导入,导出,数据之间的传输[两台服务器]2.连接管理3.服务器管理4.表的管理
- Azure AD Connect 手动同步
我们目前采用工具Azure AD Connect 目录同步工具将本地域控制器的用户信息同步至office365和Azure 在之前目录同步工具中使用Windows 任务计划程序或单独的 Windows ...
- 以.net core重构原有.net framework过程中的一些API变更记录(持续更新)
1)Type.IsGenericType类似属性变更 以下是.net framework 4.5中Type抽象类中泛型类型的几个个属性,用于泛型类型的相关信息判断: 以下是.net core(nets ...
- js中类型识别的方法
第一种方法typeof typeof是一种运算符,它的值有以下几种 <!DOCTYPE html> <html lang="en"> <head> ...
- 将字符串中的URL 解析,获取内容
parse_str() : parse_str("name=Bill&age=60"); echo $name."<br>";//Bill ...