pid=4726">http://acm.hdu.edu.cn/showproblem.php?

pid=4726

大致题意:给两个长度小于10^6且相等的合法的正整数。你能够随意组合每一个数中的数字,但不能有前导零。两个数相加的规则如题,相加不进位。

问能够得到的A+B的最大值。



都看错题意了,一直以为数的大小是小于10^6,队友用了一个ms非常高端的函数对字符串全排列,枚举求最大值。结果WA到死。事实上是长度小于10^6,以后看题要细心再细心啊。

。。

用数组记录每一个数中每一个数字的个数。每次都找从两个字符串中找和最大的,但求第一个数时要注意,不能有前导零。除了第一位,后面的每次找和最大的就可以。最后别忘了去掉前导零。以及结果是0的特殊情况。

#include <stdio.h>
#include <iostream>
#include <map>
#include <stack>
#include <vector>
#include <math.h>
#include <string.h>
#include <queue>
#include <string>
#include <stdlib.h>
#include <algorithm>
#define LL long long
#define _LL __int64
#define eps 1e-8
#define PI acos(-1.0)
using namespace std; const int maxn = 1000010; int fir[12],sec[12];
char s1[maxn],s2[maxn],ans[maxn]; int main()
{
int test,len;
scanf("%d",&test); for(int item = 1; item <= test; item++)
{
scanf("%s %s",s1,s2);
len = strlen(s1);
memset(fir,0,sizeof(fir));
memset(sec,0,sizeof(sec)); if(strcmp(s1,"0") == 0)
{
printf("Case #%d: ",item);
printf("%s\n",s2);
continue;
} if(strcmp(s2,"0") == 0)
{
printf("Case #%d: ",item);
printf("%s\n",s1);
continue;
} for(int i = 0; i < len; i++)
{
fir[s1[i]-'0']++;
sec[s2[i]-'0']++;
} int cnt = 0;
int Max = -1;
int a,b; //找第一个数字,不能找前导零
for(int i = 1; i <= 9; i++)
{
if(fir[i] == 0)
continue;
for(int j = 1; j <= 9; j++)
{
if(sec[j] == 0) continue;
int t = (i+j)%10;
if(t > Max)
{
Max = t;
a = i;
b = j;
}
}
} ans[++cnt] = Max + '0';
fir[a]--;
sec[b]--; while(cnt < len)
{
Max = -1;
for(int i = 0; i <= 9; i++)
{
if(fir[i] == 0) continue;
for(int j = 0; j <= 9; j++)
{
if(sec[j] == 0) continue;
int t = (i+j)%10;
if(t > Max)
{
Max = t;
a = i;
b = j;
}
}
}
ans[++cnt] = Max + '0';
fir[a]--;
sec[b]--;
}
printf("Case #%d: ",item);
int i;
for(i = 1; i <= len; i++)
if(ans[i] != '0')
break;
//假设是0,直接输出0
if(i == len+1)
printf("0\n");
else
{
for( ;i <= len; i++)
printf("%c",ans[i]);
printf("\n");
}
}
return 0;
}





最新文章

  1. 一步一步学FRDM-KE02Z(一):IAR调试平台搭建以及OpenSDA两种工作模式设置
  2. JavaScript:声明变量名的语法规则
  3. Java 代码完成删除文件、文件夹操作
  4. VB发送后台按键和组合键
  5. Java EE 和 Java Web
  6. 虚拟机:Python虚拟机的基本了解
  7. 创建Struct2的web应用(一)
  8. 【wp之二 页面布局】
  9. php实现MVC
  10. html5上传本地图片,在线预览及裁剪(filereader,canvas)
  11. dataStage 7.5.1A
  12. SQLServer数据类型优先级对性能的影响
  13. Android 模块化探索与实践
  14. servlet的执行过程
  15. JSTL标签四种判断语句的用法
  16. 龙芯yl8089无声音的解决方案
  17. adb错误 - INSTALL_FAILED_NO_MATCHING_ABIS
  18. [原创]K8 MSF Bind Shell TCP 连接工具
  19. numpy中loadtxt 的用法
  20. Python3基础 file open 打开txt文件并打印出全文

热门文章

  1. hdu 4445
  2. 关于键盘冲突那点事(3键冲突/7键冲突/PS2/USB的各种原理)
  3. Python还是很重要的,不能丢。学习IF和WHILE
  4. Java 声明和访问控制(二) this关键字的访问
  5. Android 窗口管理
  6. SIFT算法:特征描述子
  7. Castle学习系列之二:Castle配置
  8. linux下出现+ ls --color=auto -l --color=auto...++ echo -ne &#39;\033]0;root@imon-2:~&#39;等
  9. 破解安装 SecureCRT 7.0.2 for mac完美破解版,mac secureCRT , apple secureCRT
  10. C语言volatile关键字