题目的意思是给你两个数字(多达10^6位)

做加法,但是有一点,没有进位(进位不算,相当于这一位相加后对10取模)

你可以任意排列两个数字中的每一位,但是不能是0开头。

现在题目要求以这种不进位的算法计算得到的最大值是多少?

看完题目就会知道,这个题目一定不是dp,或者说根本不是什么高端的算法,那是什么呢?

对,你没有猜错——贪心。

为什么可以用贪心呢?我们比较一个数,都是从高位的先比较,所以只要高位的大,这个数就大;于是我们要得到最大的和,就要先统计能够构成多少个9,多少个8……(有大的就先构成大的!)。

但是考虑到首位不能是0这个特殊条件,我们需要对首位进行精心的选择。怎么选?首先看能够用两位废0数构成9,如果不行,那就构成8,7……

知道找到能够用两个非0数构成的最大数为止,这个数就是最前的(最高位)。

最最容易错的一点就是你怎么得到你构成的取法是最优的呢?

我们除了要得到一个最大的首位以外,还要考虑我们得到了这个数字后会影响我们获得其他的数字吗?

所以我们除了要得到一个最大的首位以外,还要保证这个首位相同的情况下,对构成其他的数字的影响最小(我个人的想法,应该是对的,觉得有为题的可以加我QQ:121462136仔细探讨一下)。

后面的就是赤裸裸的贪心了。

我的代码:(A了是A了,我觉得也可能是题目的数据有点弱呢,我觉得我这个方法也不是很对的赶脚,诶,不好说,欢迎联系我指出错误)

#include <iostream>
#include <cstdio>
#include <cstring>
#define maxn 1000100
using namespace std; char s[maxn];
int
a[][],t,lead,tep,num[],tot,cas=; int count1(int A)//考虑第一个数字取A,影响能构成的一个数字并返回
{

for
(int i=; i>; i--)
{

int
B=(+i-A)%;
if
(a[][A] && a[][B]) return i;
}

return
;
}
int count2(int B)//与上同理,只是第二组取B
{

for
(int i=; i>; i--)
{

int
A=(+i-B)%;
if
(a[][A]&& a[][B]) return i;
}

return
;
}
void getlead()//找首位数字
{

int
affect=,A=;
for
(int a1=; a1<=; a1++)
{

int
a2=(+-a1)%;
if
(a1*a2 && a[][a1] && a[][a2])
{

lead=;
a[][a1]--,a[][a2]--;
return
;
}
}//如果是9,不用考虑对别的影响(想想为什么?)

for
(lead=; lead>; lead--)
{

for
(int a1=; a1<=; a1++)
{

int
a2=(+lead-a1)%;
if
(a1*a2 && a[][a1] && a[][a2])
{

if
(max(count1(a1),count2(a2))<affect) affect=max(count1(a1),count2(a2)),A=a1;//取影响的数字最小的。
}
}

if
(A>)//找到非0的首位了,上下都要减去一个作为更新
{

a[][A]--;
a[][(+lead-A)%]--;
return
;
}
}
}
int main()
{

scanf("%d",&t);
while
(t--)
{

lead=;
memset(a,,sizeof a);
memset(num,,sizeof num);
scanf("%s",s); tot=strlen(s);
for
(int i=; s[i]; i++) a[][s[i]-'0']++;
scanf("%s",s);
for
(int i=; s[i]; i++) a[][s[i]-'0']++;
getlead();
for
(int i=; i>; i--)//枚举假设构成的数字为i,从大到小嘛,先构成大的。
{

for
(int a1=; a1<=; a1++)
{

int
a2=(+i-a1)%;
tep=min(a[][a1],a[][a2]);
a[][a1]-=tep,a[][a2]-=tep;
num[i]+=tep;
}
}

printf("Case #%d: ",++cas);
if
(lead==)//首位为0的话就说明答案为0
{

printf("0\n");
}

else//否则说明答案一定有n位(想想为什么?)

{

printf("%d",lead);
tot--;
for
(int i=; i>; i--)
{

for
(int j=; j<=num[i]; j++) printf("%d",i);
tot-=num[i];
}

for
(int i=; i<=tot; i++) printf("0");
printf("\n");
}
}

return
;
}

HDU4726——Kia's Calculation——2013 ACM/ICPC Asia Regional Online —— Warmup2的更多相关文章

  1. 2013 ACM/ICPC Asia Regional Online —— Warmup2 ABEGKL

    HDU4716 A. A Computer Graphics Problem A题目描述 题意:输出手机剩余电量,保证给出的数是10的倍数. 题解:水题,按题意输出即可. 代码: #include & ...

  2. 2013 ACM/ICPC Asia Regional Online —— Warmup2

    HDU 4716 A Computer Graphics Problem 水题.略 HDU 4717 The Moving Points 题目:给出n个点的起始位置以及速度矢量,问任意一个时刻使得最远 ...

  3. HDU4722——Good Numbers——2013 ACM/ICPC Asia Regional Online —— Warmup2

    今天比赛做得一个数位dp. 首先声明这个题目在数位dp中间绝对是赤裸裸的水题.毫无技巧可言. 题目的意思是个你a和b,要求出在a和b中间有多少个数满足数位上各个数字的和为10的倍数. 显然定义一个二维 ...

  4. HDU 4717 The Moving Points(三分法)(2013 ACM/ICPC Asia Regional Online ―― Warmup2)

    Description There are N points in total. Every point moves in certain direction and certain speed. W ...

  5. HDU 4719 Oh My Holy FFF(DP+线段树)(2013 ACM/ICPC Asia Regional Online ―― Warmup2)

    Description N soldiers from the famous "*FFF* army" is standing in a line, from left to ri ...

  6. HDU 4722 Good Numbers(位数DP)(2013 ACM/ICPC Asia Regional Online ―― Warmup2)

    Description If we sum up every digit of a number and the result can be exactly divided by 10, we say ...

  7. HDU 4725 The Shortest Path in Nya Graph(最短路径)(2013 ACM/ICPC Asia Regional Online ―― Warmup2)

    Description This is a very easy problem, your task is just calculate el camino mas corto en un grafi ...

  8. hduoj 4710 Balls Rearrangement 2013 ACM/ICPC Asia Regional Online —— Warmup

    http://acm.hdu.edu.cn/showproblem.php?pid=4710 Balls Rearrangement Time Limit: 6000/3000 MS (Java/Ot ...

  9. hduoj 4708 Rotation Lock Puzzle 2013 ACM/ICPC Asia Regional Online —— Warmup

    http://acm.hdu.edu.cn/showproblem.php?pid=4708 Rotation Lock Puzzle Time Limit: 2000/1000 MS (Java/O ...

随机推荐

  1. JS截图(html2canvas)

    JS截图(html2canvas) • 引入js <script type="text/javascript" src="js/html2canvas.js&quo ...

  2. windows系统下构建Jenkins持续集成

    环境准备 windows10+tomcat+python3.x(安装方法自行百度) 安装Jenkins 从https://jenkins.io/download/ 下载war包 将war包放到tomc ...

  3. centos安装及Xshell连接配置

    一.百度下载并安装VMware 二.下载centos 打开https://www.centos.org,点击“get centos now”,点击“DVD ISO”下载(也可以下滑点击“more do ...

  4. 【转】sshpass-Linux命令之非交互SSH密码验证

      sshpass-Linux命令之非交互SSH密码验证 ssh登陆不能在命令行中指定密码.sshpass的出现,解决了这一问题.sshpass用于非交互SSH的密码验证,一般用在sh脚本中,无须再次 ...

  5. Android Library和Android APP、Java Library的区别

    Android Library和Android APP.Java Library的区别 Android Library在目录结构上与Android App相同,它能包含构建APP所需的一切(如源代码. ...

  6. Netty源码分析第3章(客户端接入流程)---->第1节: 初始化NioSockectChannelConfig

    Netty源码分析第三章: 客户端接入流程 概述: 之前的章节学习了server启动以及eventLoop相关的逻辑, eventLoop轮询到客户端接入事件之后是如何处理的?这一章我们循序渐进, 带 ...

  7. python—启动自带shell时报错(丢失api-ms-win-crt-runtime-l1-1-0.dll)已解决

    备注: 有的伙伴安装完1后重启,问题可以解决,summer儿在安装完1依然未能解决,于是又进行了2的安装再次重启后问题解决!! 1,安装vc-redist.x64,微软官网搜索免费下载,安装后重启. ...

  8. [shell] 脚本之shift和getopts (转载)

    转载地址:http://www.361way.com/shell-shift-getopts/4973.html 建议不熟悉getopts的朋友,此篇要看完,getopts部分内容在原作者上面有改动. ...

  9. PHP的垃圾回收

    PHP使用引用计数和写时拷贝(Copy-On-Write)来管理内存. 引用技术不言自明,写时拷贝工作原来如下: $worker = array("Fred", 35, " ...

  10. PSP总结报告1

    回答作业问题 1.回想一下你曾经对计算机专业的畅想 我高考后报考的是计算机科学与技术,当时对计算机技术基本了解为零,当时以为什么东西都会用到计算机,学计算机以后不会找不到工作,刚开学的时候对计算机一窍 ...