博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
最佳加法表达式
阅读量:7044 次
发布时间:2019-06-28

本文共 2386 字,大约阅读时间需要 7 分钟。

011:最佳加法表达式

总时间限制: 
1000ms 
内存限制: 
65536kB
描述

给定n个1到9的数字,要求在数字之间摆放m个加号(加号两边必须有数字),使得所得到的加法表达式的值最小,并输出该值。例如,在1234中摆放1个加号,最好的摆法就是12+34,和为36

输入
有不超过15组数据
每组数据两行。第一行是整数m,表示有m个加号要放( 0<=m<=50)
第二行是若干个数字。数字总数n不超过50,且 m <= n-1
输出
对每组数据,输出最小加法表达式的值
样例输入
21234561123456412345
样例输出
10257915
提示
要用到高精度计算,即用数组来存放long long 都装不下的大整数,并用模拟列竖式的办法进行大整数的加法。
来源
Guo Wei

解题思路

代码

#include
#include
#include
using namespace std; const int MaxLen = 55; const string maxv = "999999999999999999999999999999999999999999999999999999999"; string ret[MaxLen][MaxLen]; string num[MaxLen][MaxLen]; int cmp(string &num1,string &num2) {
int l1 = num1.length(); int l2 = num2.length(); if (l1 != l2) {
return l1-l2; } else {
for (int i=l1-1; i>=0; i--) {
if (num1[i]!=num2[i]) {
return num1[i]-num2[i]; } } return 0; } } void add (string &num1,string &num2,string &num3) {
//加法从低位到高位相加,那么需要将字符串倒过来 int l1 = num1.length(); int l2 = num2.length(); int maxl = MaxLen,c = 0; //c是进位标志 for (int i=0; i
= l2) {
t = num1[i] - '0' + c; } else if (i >= l1 && i < l2) {
t = num2[i] - '0' + c; } else {
break; } num3.append(1,t%10+'0'); c = t/10; } while (c) {
num3.append(1,c%10+'0'); c /= 10; } } int main() {
int m; //加号数目 string str; //输入的字符串 while(cin >> m >> str) {
//为了之后的加法计算先将这个字符串倒过来 reverse(str.begin(),str.end()); int n = str.length(); for (int i=0; i
0) {
minv = tmp; } } ret[i][j] = minv; } } //将原先颠倒的字符串倒回来 reverse(ret[m][n].begin(),ret[m][n].end()); cout << ret[m][n] << endl; } return 0; }

转载于:https://www.cnblogs.com/JingwangLi/p/10202844.html

你可能感兴趣的文章
【翻译svg教程 】svg 的坐标系统
查看>>
彻底理解线索二叉树
查看>>
JMeter学习笔记--详解JMeter定时器
查看>>
3.Java网络编程之IP
查看>>
数学之树
查看>>
JAVA CAS原理深度分析
查看>>
SQL里3个表的连接查询
查看>>
Java面试题汇总(一)
查看>>
编写带有点击特效的UIButton
查看>>
ASP.NET MVC下的异步Action的定义和执行原理[转]
查看>>
什么是软件架构(转)
查看>>
PHP大小写是否敏感问题
查看>>
七天学会ASP.NET MVC(七)——创建单页应用
查看>>
struts2由&lt;s:tree&gt;要么dtree小工具 建立树
查看>>
[C#] zdbviewcs: 跨平台数据库查看器。支持SqlServer、Oracle、MySql等数据库
查看>>
如何实现Web聊天
查看>>
使用CLion
查看>>
Tomcat下JSP、Servlet和JavaBean环境的配置
查看>>
给phpcms v9加入一个主题radio无线电button,它可反复使用,以创建不同的专题部分内容编辑器,添加一个主题来定义自己的领域...
查看>>
UVa 514 Rails(经典栈)
查看>>