ACdream 1068
我没有用二分法,直接构造最小数,既然题目保证答案一定存在那么与上界无关。
如给定S=16,它能构成的最小数为79,尽量用9补位,最高位为S%9.如果构造的数大于下界A,那么直接输出,因为这是S能构成的最小数;小于下界就要分两种情况了,第一种情况就是A的各位的和P小于S,那么从最低位一直向高位不,最高补9,补不到9,就补能补的最大数;第二种情况就是P大于S,那么就从最高位枚举,看能否补成和A同样的数,如不能立即返回上一位,加1,如果小于9,那么高位确定,剩下的就利用“尽量用9补位,最高位为S%9”的方法构造。
这题还有个坑人的地方,题目并没有说是多数据输入,但是如果用单组数据数据,会WA
AC代码:
#include<cstdio> #include<cstring> const int maxn=23; char a[maxn],b[maxn]; int tmp[maxn],ans[maxn],c; int main(){ while(scanf("%s%s%d",a,b,&c)==3){ int lenth=strlen(a); long long x=0; for(int i=0;i<lenth;++i){ tmp[i+1]=a[i]-'0'; x=x*10+a[i]-'0'; } int num=c; tmp[0]=ans[0]=0; long long y=num%9; for(int i=0;i<num/9;++i) y=y*10+9; if(y>=x) printf("%lld",y); else if(y<x){ int p=0; lenth++; for(int i=1;i<lenth;++i) p+=tmp[i]; if(p<=num){ for(int i=0;i<lenth;++i) ans[i]=tmp[i]; num-=p; for(int i=lenth-1;i>=0&&num>0;--i){ if(ans[i]+num>=9){ num-=9-ans[i]; ans[i]=9; } else { ans[i]+=num; num=0; } } if(ans[0]) printf("%d",ans[0]); for(int i=1;i<lenth;++i) printf("%d",ans[i]); } else { int h=num,ind; for(int i=0;i<lenth;++i){ ans[i]=0; if(tmp[i]>ans[i]){ num-=tmp[i]-ans[i]; ans[i]=tmp[i]; } if(num<=0){ int k; for(k=i-1;k>=0;--k){ ans[k]++; if(ans[k]<10) break; } ind=k+1; break; } } for(int i=0;i<ind;++i) h-=ans[i]; for(int i=ind;i<lenth;++i) ans[i]=0; for(int i=lenth-1;i>lenth-1-h/9;--i) ans[i]=9; if(h%9) ans[lenth-1-h/9]=h%9; if(ans[0]) printf("%d",ans[0]); for(int i=1;i<lenth;++i) printf("%d",ans[i]); } } printf("\n"); } return 0; }
如有不当之处欢迎指出!
ACdream 1068的更多相关文章
- w3svc服务启动 不了,错误 1068:依赖服务或组件无法启动
win10系统,装了iis就是启动不了,报错误 1068:依赖服务或组件无法启动. 各种实验无法使用,最后如下方法解决 运行命令regedit,打开注册表编辑器,进入:HKEY_LOCAL_MACHI ...
- BZOJ 1068: [SCOI2007]压缩
Sol 区间DP.这个区间DP需要三维, \(f[i][j][k]\) 表示\([i,j]\) 这个区间中是否存在 \(M\) . 转移有两种,一种是这个区间存在 \(M\) ,那么直接枚举 \(M\ ...
- POJ 1068
http://poj.org/problem?id=1068 这道题是一道模拟的题目 题目大意呢,p代表前面的'('的个数,而w代表这个括号所包括的括号的个数: 给你p,要你求w: 解题思路: 首先, ...
- ACdream 1214---矩阵连乘
ACdream 1214---矩阵连乘 Problem Description You might have noticed that there is the new fashion among r ...
- acdream.LCM Challenge(数学推导)
LCM Challenge Time Limit:1000MS Memory Limit:64000KB 64bit IO Format:%lld & %llu Submit ...
- acdream.Triangles(数学推导)
Triangles Time Limit:1000MS Memory Limit:64000KB 64bit IO Format:%lld & %llu Submit Stat ...
- acdream.A Very Easy Triangle Counting Game(数学推导)
A - A Very Easy Triangle Counting Game Time Limit:1000MS Memory Limit:64000KB 64bit IO Forma ...
- acdream.Bet(数学推导)
Bet Time Limit:1000MS Memory Limit:64000KB 64bit IO Format:%lld & %llu Submit Status Pra ...
- acdream.郭式树(数学推导)
郭式树 Time Limit:2000MS Memory Limit:128000KB 64bit IO Format:%lld & %llu Submit Status Pr ...
随机推荐
- [Gradle] 在 Eclipse 下利用 gradle 构建系统
转载自:http://www.ibm.com/developerworks/cn/opensource/os-cn-gradle/ 构建系统时候常常要用到 Ant, Maven 等工具,对于初学者 ...
- linkin大话面向对象--接口
接口(interface)的概念,掌握接口很重要,以后所有的编程都要面向接口编程.其实接口的内涵就7个字:规范和实现分离. 抽象类是从多个类中抽象出来的模板,若要将这种抽象进行得更彻底,就得用到一种特 ...
- C# String StringBuilder 区别
这篇博客,纯参考.主要为了自己也复习一遍,过一下其中的原理. string aTest = "abc";//分配固定的内存大小 aTest += "ddd"; ...
- shell第二篇
第二篇知道shell是什么,再来了解一下shell的分类及相关历史 参考百度百科:shell 1.shell概念(计算机壳层) 在计算机科学中,Shell俗称壳(用来区别于核),是指"提供使 ...
- form表单中get和post两种提交方式的区别
一.form表单中get和post两种提交方式的区别? 1.get提交表单中的内容在链接处是可见的.post不可见 2.post相比于get是安全的 3.post不收限制大小,get有限制大小(黑马视 ...
- 浅谈 HTML5plus 开发移动应用
什么是 HTML5plus DCloud 公司提供的,使用传统 web 技术开发移动应用的解决方案. 增强版的手机浏览器引擎,让HTML5达到原生水平! 产品口号,总会有些夸张的成分,不要在意这些细节 ...
- Python学习笔记(三): 收集参数
如下代码: >>>def print_params(title,*params) print title print params >>>print_params( ...
- c# excel print 打印 将所有列调整为一页
excel有时候列数比较多,行数也比较多,转换成xps文档的时候,一般是通过打印来实现. 由于打印的范围限制,所以会出现本来在一行的数据,由于列数比较多,溢出范围,被打印到两页了. 为解决这个问题,需 ...
- 通过SMTP发送邮件的Python代码
贴上一段用Python开发的发送邮件程序 #coding=UTF-8 import smtplib from email.mime.text import MIMEText smtp_host=&qu ...
- Eclipse的调试功能的10个小窍门[转]
原文链接:http://www.importnew.com/6164.html 你可能已经看过一些类似“关于调试的N件事”的文章了.但我想我每天大概在调试上会花掉1个小时,这是非常多的时间了.所以非常 ...