BZOJ1386 : [Baltic2000]Stickers
显然每一位的限制独立,对于每一位求出仅限制该位下的最大数,然后求最小值即可。
假设当前要求数字$d$的答案:
考虑填数字的过程,可以看作依次考虑一个序列中的每个数,当前缀和$<0$时退出。
设$dp[i][j][k]$表示正在考虑最低的$i$位,高位部分有$j$个$d$,第$i$位能不能填$0$为$k$时,所有可能的数字形成的序列的信息。
这个信息需要维护两个值:
- $f$:前缀和最小值。
- $s$:总和。
显然这个信息可以进行合并。
求出答案的位数后,再从高到低逐位确定即可。
时间复杂度$O(\log^2n)$。
- #include<cstdio>
- #include<algorithm>
- using namespace std;
- const int N=100,B=10000,MAXL=25;
- int cur,v[N][N][2];
- struct Num{
- int a[MAXL],len,fu;
- Num(){len=1,fu=a[1]=0;}
- void clr(){len=1,fu=a[1]=0;}
- Num operator+(const Num&b)const{
- Num c;
- c.len=max(len,b.len)+2;
- int i;
- for(i=1;i<=c.len;i++)c.a[i]=0;
- if(fu==b.fu){
- for(i=1;i<=len;i++)c.a[i]=a[i];
- for(i=1;i<=b.len;i++)c.a[i]+=b.a[i];
- for(i=1;i<=c.len;i++)if(c.a[i]>=B)c.a[i+1]++,c.a[i]-=B;
- while(c.len>1&&!c.a[c.len])c.len--;
- c.fu=fu;
- }else{
- bool flag=0;
- if(len==b.len){
- for(i=len;i;i--)if(a[i]!=b.a[i]){
- if(a[i]>b.a[i])flag=1;
- break;
- }
- }else{
- if(len>b.len)flag=1;
- }
- if(flag){
- for(i=1;i<=len;i++)c.a[i]=a[i];
- for(i=1;i<=b.len;i++)c.a[i]-=b.a[i];
- for(i=1;i<=c.len;i++)if(c.a[i]<0)c.a[i+1]--,c.a[i]+=B;
- while(c.len>1&&!c.a[c.len])c.len--;
- c.fu=fu;
- }else{
- for(i=1;i<=b.len;i++)c.a[i]=b.a[i];
- for(i=1;i<=len;i++)c.a[i]-=a[i];
- for(i=1;i<=c.len;i++)if(c.a[i]<0)c.a[i+1]--,c.a[i]+=B;
- while(c.len>1&&!c.a[c.len])c.len--;
- c.fu=b.fu;
- }
- }
- return c;
- }
- Num operator-(Num b)const{
- b.fu^=1;
- return *this+b;
- }
- Num operator*(const Num&b)const{
- Num c;
- c.len=len+b.len+2;
- c.fu=fu^b.fu;
- int i,j;
- for(i=1;i<=c.len;i++)c.a[i]=0;
- for(i=1;i<=len;i++)for(j=1;j<=b.len;j++){
- c.a[i+j-1]+=a[i]*b.a[j];
- if(c.a[i+j-1]>=B){
- c.a[i+j]+=c.a[i+j-1]/B;c.a[i+j-1]%=B;
- if(c.a[i+j]>=B)c.a[i+j+1]+=c.a[i+j]/B,c.a[i+j]%=B;
- }
- }
- while(c.len>1&&!c.a[c.len])c.len--;
- return c;
- }
- bool iszero()const{
- return len==1&&!a[1];
- }
- void write(){
- if(len==1&&!a[1])fu=0;
- if(fu)putchar('-');
- printf("%d",a[len]);
- for(int i=len-1;i;i--)printf("%04d",a[i]);
- }
- void set(int x){
- if(x<0)fu=1,x=-x;else fu=0;
- if(x>=B){
- len=2;
- a[1]=x%B;
- a[2]=x/B;
- }else{
- len=1;
- a[1]=x;
- }
- }
- int sgn()const{
- if(iszero())return 0;
- return fu==1?-1:1;
- }
- int cmp(const Num&b)const{
- int x=sgn(),y=b.sgn();
- if(x!=y)return x<y?-1:1;
- if(!x)return 0;
- if(x>0){
- if(len!=b.len)return len<b.len?-1:1;
- for(int i=len;i;i--)if(a[i]!=b.a[i])return a[i]<b.a[i]?-1:1;
- return 0;
- }
- if(len!=b.len)return len>b.len?-1:1;
- for(int i=len;i;i--)if(a[i]!=b.a[i])return a[i]>b.a[i]?-1:1;
- return 0;
- }
- bool operator<(const Num&b)const{return cmp(b)<0;}
- bool operator==(const Num&b)const{return cmp(b)==0;}
- bool operator>(const Num&b)const{return cmp(b)>0;}
- }ans,val[11];
- struct P{
- Num f,s;
- P(){f.clr();s.clr();}
- void clr(){f.clr();s.clr();}
- P(Num _f,Num _s){f=_f,s=_s;}
- P operator+(const P&b)const{return P(min(f,s+b.f),s+b.s);}
- void operator+=(const P&b){*this=*this+b;}
- }base,f[N][N][2];
- P dfs(int x,int y,int z){
- if(x==0){
- P t;
- t.f.set(-y);
- t.s.set(-y);
- return base+t;
- }
- if(v[x][y][z]==cur+1)return f[x][y][z];
- v[x][y][z]=cur+1;
- P t;
- t.clr();
- for(int i=z;i<10;i++)t+=dfs(x-1,y+(i==cur),0);
- return f[x][y][z]=t;
- }
- Num solve(int _cur,int _base){
- cur=_cur;
- base.f.set(0);
- base.s.set(_base);
- int i,j,len;
- P pre;
- pre.clr();
- for(len=1;;len++){
- P now=dfs(len,0,1);
- if((pre+now).f.sgn()<0)break;
- pre+=now;
- }
- Num ans=val[0];
- int sum=0;
- for(i=len;i;i--)for(j=i==len?1:0;;j++){
- int nowsum=sum+(j==cur);
- P now=dfs(i-1,nowsum,0);
- if((pre+now).f.sgn()<0){
- sum=nowsum;
- ans=ans*val[10]+val[j];
- break;
- }
- pre+=now;
- }
- return ans;
- }
- int main(){
- for(int i=0;i<11;i++)val[i].set(i);
- for(int i=0;i<10;i++){
- int x;
- scanf("%d",&x);
- if(i==0)ans=solve(i,x);
- else ans=min(ans,solve(i,x));
- }
- ans=ans-val[1];
- ans.write();
- return 0;
- }
BZOJ1386 : [Baltic2000]Stickers的更多相关文章
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- bzoj1385: [Baltic2000]Division expression
欧几里得算法.可以发现规律,a[2]作为分母,其他作为分子,必定是最好的选择.判断是否为整数即可. #include<cstdio> #include<cstring> #in ...
- BZOJ 1385: [Baltic2000]Division expression
题目 1385: [Baltic2000]Division expression Time Limit: 5 Sec Memory Limit: 64 MB Description 除法表达式有如下 ...
- About Unixstickers - Unixstickers - stickers on unix, programming, software, development and open source
About Unixstickers - Unixstickers - stickers on unix, programming, software, development and open so ...
- [LeetCode] Stickers to Spell Word 贴片拼单词
We are given N different types of stickers. Each sticker has a lowercase English word on it. You wou ...
- [Swift]LeetCode691. 贴纸拼词 | Stickers to Spell Word
We are given N different types of stickers. Each sticker has a lowercase English word on it. You wou ...
- 使用Stickers拓展集成iMessage简单功能
添加一个target,选择Stickers拓展: 然后就会出现iMessage的文件夹:添加你需要的iMessage图片,这里图片遵循下面的要求: Small: 100 x 100 pt @3x sc ...
- LeetCode691. Stickers to Spell Word
We are given N different types of stickers. Each sticker has a lowercase English word on it. You wou ...
- 691. Stickers to Spell Word
We are given N different types of stickers. Each sticker has a lowercase English word on it. You wou ...
随机推荐
- Java中方法定义和调用的学习
方法其实就是若干语句的功能集合. 参数(原料):就是进入方法的数据.返回值(原产物):就是从方法中出来的数据. 定义方法的完整格式:修饰符 返回值类型 方法名称(参数类型 参数名称,...){ 方 ...
- Ubuntu18.04应用程序安装集锦
整理网上的资源: Python Web开发工具箱 ubuntu美化及超NB的zsh配置 api文档查询工具:zeal,dash(收费)
- Css - 选择器和样式
Css - 选择器和样式 标签选择器 即使用html标签作为选择对象 <style> div{ background:red; } </style> <div&g ...
- sql注入--双查询报错注入原理探索
目录 双查询报错注入原理探索 part 1 场景复现 part 2 形成原因 part 3 报错原理 part 4 探索小结 双查询报错注入原理探索 上一篇讲了双查询报错查询注入,后又参考了一些博客, ...
- [Kubernetes]基于角色的权限控制之RBAC
Kubernetes中有很多种内置的编排对象,此外还可以自定义API资源类型和控制器的编写方式.那么,我能不能自己写一个编排对象呢?答案是肯定的.而这,也正是Kubernetes项目最具吸引力的地方. ...
- L2-007 家庭房产 (25 分) (并查集)
链接:https://pintia.cn/problem-sets/994805046380707840/problems/994805068539215872 题目: 给定每个人的家庭成员和其自己名 ...
- 医学图像数据(一)——TCIA基本介绍
1.介绍 The Cancer Imaging Archive (TCIA)是癌症研究的医学图像的开放获取数据库.该网站由国家癌症研究所(NCI)癌症影像计划资助,合同由阿肯色大学医学科学院管理.存档 ...
- 变分自编码器(Variational Autoencoder, VAE)通俗教程
原文地址:http://www.dengfanxin.cn/?p=334 1. 神秘变量与数据集 现在有一个数据集DX(dataset, 也可以叫datapoints),每个数据也称为数据点.我们假定 ...
- web文件下载
web页面实现文件下载的几种方法 今天碰到文件下载的一些问题,本着知其然也要知其所以然的精神,站在巨人的肩膀上深入学习和测试了一下,抛砖引玉,现在总结结论如下: 1)标准URL下载方式可以通过在web ...
- vertx的HttpServer模块
Start HttpServer /** * 启动 HttpServer * multi instances 采用 synchronized防止线程安全问题 * addHandlers 方法是acto ...