E:最小表达式

考察点 : 贪心,高精度
坑点 : 高精度一定不要写错,一定一定不要写错
剩下的就是细节问题

侃侃 :

1、字符串长度达到 5e5,如果要涉及到加法,乘法,普通的肯定会爆 long long的,那么就需要用到
高精度了。
2、怎么贪呢 ?
一个数怎么样会最小呢?只有最高位最小,然后次高位较小,这是这个数就应该会最小(可以自己模拟一下)
另外,这个字符串中的所有 '+' 我们肯定都会用到,因为只有这样所得到的和才会更小,所以如果 ‘+’ 有
ans 个,那么我们就可以将所有整个字符串分成 ans + 1 份。
接下来将所有字符进行排序(从小到大),然后平均分配到每一份中,最后用高精度进行 累加即可(刚开始我还
想着先 * 10 + 某个字符,实际上根本不用,因为我们的每一份就是一个整数,而在大数相加的时候也是字符串
所以直接相加即可)
3、注意高精度一定不要写错,否则真的过不了

Code:

#include <vector>
#include <cstdio>
#include <string>
#include <cstring>
#include <iostream>
#include <algorithm> using namespace std; const int maxn = 5 * 1e5 + 100;
typedef long long LL; char str[maxn];
int a[maxn];
vector<int>ve[maxn];
vector<int>res; vector<int> add(vector<int> &A,vector<int> &B) {
if(A.size() < B.size()) return add(B,A); // 尽量用长的 + 短的,因为这样多余的部分我们就可以直接进行处理了
vector<int> C; // 设置一个 vector 类型的变量,用来作为返回的值
int t = 0;
for(int i = 0; i < A.size(); i ++) {
t += A[i];
if(B.size() > i) t += B[i]; // B 有一定的限制,不能一直加 呀
C.push_back(t % 10);
t /= 10; // 进位
}
if(t) C.push_back(t); // 可能会多出来一个,例如3位数 + 3 位数 ,结果有可能是 4 位数
return C; } int main(void) {
int ans = 0,len;
bool vis = false;
scanf("%s",str + 1);
len = strlen(str + 1);
int a_num = 1;
for(int i = 1; i <= len; i ++) {
if(str[i] == '+') {
ans ++; // '+' 的次数
} else {
a[a_num ++] = str[i] - '0';
}
}
if(ans != 0)
ans ++; // 份数应该 + 1
sort(a + 1,a + a_num);
if(ans == 0) {
for(int i = 1; i <= len; i ++) {
cout << a[i];
}
cout << endl;
} else {
int pos = 0;
for(int i = 1; i <= a_num - 1; i ++) {
if(i % ans == 0) {
pos ++;
ve[pos].push_back(a[i]);
pos = 0;
continue;
}
pos ++;
ve[pos].push_back(a[i]);
}
for(int i = 1; i <= ans; i ++) {
// 取反,便于下面进行计算
reverse(ve[i].begin(),ve[i].end());
res = add(res,ve[i]);
} for(int i = res.size() - 1; i >= 0; i --) {
cout << res[i];
}
cout << endl;
}
return 0;
}

最新文章

  1. Linux系统下配置JDK环境变量
  2. 更便捷的Android多渠道打包方式
  3. GIT之旅【第一篇】
  4. Web Service和WCF的到底有什么区别
  5. 锋利的jQuery-6--序列化函数serialize()和serializeArray()在表单提交中的作用
  6. [原]在Fedora中编译Libevent测试实例
  7. [转]编译错误: /bin/sh: 1: pushd: not found的问题
  8. LeetCode ---Anagrams() 详解
  9. java使用POI jar包读写xls文件
  10. 编码识别工具:hash-identifier
  11. 调查:Java程序员最亲睐的Web框架
  12. linux下解压压缩rar文件
  13. 01我为什么学Unity3d
  14. Robert Penner's Easing Functions
  15. 通过 Spring RestTemplate 调用带请求体的 Delete 方法(Delete With Request Body)
  16. 基于Qt语音识别功能
  17. 使用myeclipse新建和删除web项目时一定要小心
  18. 解决ubuntu无法远程连接
  19. C# 导入excel报错 :不是预期外部表
  20. Ztree的onClick和onCheck事件

热门文章

  1. Python在Windows下列出所有的安装包和模块
  2. 1z0-062 题库解析5
  3. 关于java php go 中AES加解密秘钥长度问题
  4. 暑假提高组集训Day1 T2
  5. nginx服务无法停止(Windows)
  6. 安装mysql8.0.17指南
  7. 个人任务day6
  8. 网鼎杯题目“phone”--十六进制mysql注入
  9. centos7的新特性
  10. 个人第4次作业——alpha项目测试