hihocoder1033交错和
题目链接
坑:
1.ll x,y;
z=x*y;可能会溢出,于是我写成x%mod*y%mod
仍旧错误,要写成x%mod*(y%mod).
2.f(9019)=1.
要注意如果为0,下一位的符号根据0的个数而变化
#include<iostream> #include<stdio.h> #include<algorithm> #include<queue> #include<math.h> #include<string.h> #include<string> #include<stdlib.h> using namespace std; typedef long long ll; typedef unsigned long long ull; #define re(i,n) for(int i=0;i<n;i++) ; /* Node cnt表示个数,sum表示和 */ struct Node{ ll cnt, sum; Node() :cnt(), sum(){} Node(ll c, ll s) :cnt(c), sum(s){} }dp[][][][];//(bits,+-,+-can change,sum) /* 19 最多19位 2 +还是- 2 是否是第一个数字 600 f(n)的结果,因为19位*9=171,输入的k是-100到100,所以范围大概是-300到+300,所以用600 */ ll ten[]; //ten[i]表示10^i void init(){ ten[] = ; ; i < ; i++){ ten[i] = * ten[i - ]; } } /*d是一个大管家,管理者dp这个数组,如果计算过,那就不再计算了 对参数做一些处理,像适配器一样 n表示[0,10^n-1]范围内,第一个符号为flag,符号是否会改变change,f(n)=k */ Node d(int n, int flag, int change, int k){ ? : ); ; Node f(ll,int, int, int); ){ dp[n][ff][change][kk] = f(ten[n] - , flag, change, k); } return dp[n][ff][change][kk]; } /* 主要逻辑都在这个函数里面,n表示[0,n]范围内的值 */ Node f(ll n, int flag, int change, int k){ ), ); ){ && flag*k <= n), flag*k); , ); } ll mi = , h = ; )h = tmp % , mi++; mi--; ll va = h*ten[mi];//处理清楚最高位 Node t = d(mi, change ? : -flag, change, k); //第一位为0时,有多少种情况 Node ans = t; ; i < h; i++){ t = d(mi, -flag, , k - flag*i); ans.cnt += t.cnt; ans.sum = (ans.sum + ten[mi]%mod*i*( t.cnt%mod) + t.sum) % mod; } //第一位为h时的情况 )?flag:-flag); ){ ff *= -; } t = f(n - va, ff, , k - flag*h); ans.cnt += t.cnt; ans.sum = (ans.sum + va%mod*(t.cnt%mod) + t.sum) % mod; return ans; } int main(){ //freopen("in.txt", "r", stdin); init(); memset(dp, -, sizeof(dp)); ll l, r, k; cin >> l >> r >> k; Node m = f(l - , ,, k), n = f( r, ,, k); ll ans = (n.sum - m.sum) % mod; )ans += mod; cout << ans << endl; ; }
别人的代码还精简,算法更好.
struct node { ll cnt,sum; //分别表示该状态的出现的次数,以及数字和 node(ll _cnt,ll _sum):cnt(_cnt),sum(_sum){} node(){} }dp[][][]; //dp[i][j][k],表示当前在的i位,第一位有效位为j,交错和为k-100的状态 ll num[]; ll ten[]; ll l,r; int k; node dfs(int cur,int first,int sum,bool limit) { ) ); ].cnt != -) ]; ; node ret(,),tv; rep(i,up+) { int g; ? : cur); } else g = first; if(g) tv = dfs(cur-,g,sum+((g-cur)%==?:-)*i,limit && i == up); else tv = dfs(cur-,,,limit && i==up); ll t = i*ten[cur-]%mod; ret.cnt = (ret.cnt + tv.cnt) % mod; //次数相加 ret.sum = (ret.sum + tv.sum + t*tv.cnt)%mod; //和相加 } ] = ret; return ret; } ll solve(ll n) { ) ; ; while(n){ num[++len] = n % ; n /= ; } ,,).sum; } void init() { memset(dp,-,sizeof(dp)); ten[] = ; ;i<;i++) ten[i] = (ten[i-] * ) % mod; } int main() { #ifndef ONLINE_JUDGE freopen("in.txt","r",stdin); // freopen("out.txt","w",stdout); #endif init(); while(~scanf("%lld%lld%d",&l,&r,&k)) { cout<<(solve(r)-solve(l-)+mod)%mod<<'\n'; } ; }
hihocoder1033交错和的更多相关文章
- hihoCoder1033 交错和 数位DP
题目:交错和 链接:http://hihocoder.com/problemset/problem/1033# 题意:对于一个十进制整数x,令a0.a1.a2.....an是x从高位到低位的数位,定义 ...
- 【hihoCoder】1033: 交错和
初探数位dp 介绍了数位类统计的基础知识.以下列出其中的基础点: 基本问题 统计在区间[l, r]中满足条件的数的个数 思路 1. [l, r] 将问题转换为 在[0, r]中满足条件的个数 - 在[ ...
- hiho#1033 : 交错和
描述 给定一个数 x,设它十进制展从高位到低位上的数位依次是 a0, a1, ..., an - 1,定义交错和函数: f(x) = a0 - a1 + a2 - ... + ( - 1)n - 1a ...
- hihoCoder #1033 : 交错和 (数位Dp)
题目大意: 给定一个数 x,设它十进制展从高位到低位上的数位依次是 a0, a1, ..., an - 1,定义交错和函数: f(x) = a0 - a1 + a2 - ... + ( - 1)n - ...
- [hihocoder 1033]交错和 数位dp/记忆化搜索
#1033 : 交错和 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描写叙述 给定一个数 x,设它十进制展从高位到低位上的数位依次是 a0, a1, ..., an - 1 ...
- hihoCoder 1033 : 交错和 数位dp
思路:数位dp,dp(i, j, k)表示考虑i位数,每位数可以任意取[0~9],并且这i位数的交错和为j,k=1表示前缀全是0(如000456),k=0表示前缀不为0.注意,前缀是否为0是这道题的一 ...
- hihoCoder 1033: 交错和
(1)题目描述: 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定一个数 x,设它十进制展从高位到低位上的数位依次是 a0, a1, ..., an - 1,定义交错 ...
- HihoCoder 1033交错和(数位DP第三题)
(写挂了,有空再补) 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定一个数 x,设它十进制展从高位到低位上的数位依次是 a0, a1, ..., an - 1,定义 ...
- 【FJWC2017】交错和查询 [线段树]
交错和查询 Time Limit: 10 Sec Memory Limit: 256 MB Description 无限循环数字串S由长度为n的循环节s构成.设s为12345(n=5),则数字串S为 ...
随机推荐
- Linux IPC tcp/ip socket 编程
模型 #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include < ...
- contiki在keil下的stm32平台移植
参考博客: http://www.aiuxian.com/article/p-705047.html http://blog.csdn.net/u013232419/article/details/4 ...
- Activity中使用Intent实现页面跳转与参数的传递(转)
新建一个FirstAvtivity.java package com.zhuguangwei; import android.app.Activity; import android.content. ...
- 禁用站点asp运行
禁用站点asp运行 进入 Mcafee 的 VirusScan 控制台,双击访问保护->进文件, 共享资源和文件夹保护,在要阻挡的文件和文件夹那点添加 规则名: 禁止网站进程在任何地方修建和修改 ...
- C#基础---扩展方法的应用
最近对扩展方法比较感兴趣,就看了看资料,记录一下扩展方法的几种方法. 一. 扩展方法的基本使用: Note: 1. 扩展方法必须在静态类中, 2 扩展方法必须声明静态方法,3 扩展方法里面不能调用其 ...
- Machine Learning Algorithms Study Notes(3)--Learning Theory
Machine Learning Algorithms Study Notes 高雪松 @雪松Cedro Microsoft MVP 本系列文章是Andrew Ng 在斯坦福的机器学习课程 CS 22 ...
- Java与模式读书笔记
>设计目标:可扩展性,灵活性,可插入性. >设计原则 ● Open Closed Principle 开闭原则 对扩展开放,对修改关闭. 对面向对象的语言来说,不可以更改的是系统的抽象层, ...
- bzoj-4517 4517: [Sdoi2016]排列计数(组合数学)
题目链接: 4517: [Sdoi2016]排列计数 Time Limit: 60 Sec Memory Limit: 128 MBSubmit: 846 Solved: 530[Submit][ ...
- Student学生管理系统
1.定义各个层 2.添加各个层之间的引用 DAL 层调用Model BLL层调用DAL和Model UI层调用BLL和Model层 Model层供各个层调用 3.根据数据库建立实体类,每张表对应一个实 ...
- Channel SDK (渠道SDK) for Unity
渠道 英文channel,解释:商品的销售路线,也就是我们开发商(CP)都把游戏开发好了,交付给渠道帮我们运营,帮我们推广,帮我们赚钱. Android和IOS渠道 拿安卓和IOS两大平台来说,它们都 ...