5.数字拆分成4段,怎样使得4段的乘积最小【dp】
2013-10-31 22:06
302 查看
题目是:给出一个数字(10,000~100,000,000),把这个数字拆分成4段,怎样使得4段的乘积最小。比如12345拆分成1*2*3*45=270, 10000=1*00*0*0=0。
题目分析:
这道题很明显能用动态规划(dp)来求解,用dp(i,j)表示:以指向第j个位置字的符结束的字符串还需要分为i份所得到的最小乘积,那么题目中的12345的正解就是dp(4,5)表示以第5个字符(‘5’)结束的字符串分成4份所得到的最小乘积。
num(i,j)表示字符串中从第i个字符到第j个字符组成的字符串的值,如12345中,num(2,4)=234
My Code:
题目分析:
这道题很明显能用动态规划(dp)来求解,用dp(i,j)表示:以指向第j个位置字的符结束的字符串还需要分为i份所得到的最小乘积,那么题目中的12345的正解就是dp(4,5)表示以第5个字符(‘5’)结束的字符串分成4份所得到的最小乘积。
num(i,j)表示字符串中从第i个字符到第j个字符组成的字符串的值,如12345中,num(2,4)=234
My Code:
#include <iostream> #include <string> using namespace std; int dp[5][20]; int num(const string &str,int b,int e) { b--; e--; int res=0; while(b<=e) { res=(str[b++]-'0')+res*10; } return res; } int main() { for(int i=0;i<5;i++) for(int j=0;j<20;j++) dp[i][j]=1; string str; cin>>str; int len=str.size(); for(int i=1;i<=4;i++) for(int j=i;j<=len;j++) { if(i==j) { int res=1; for(int t=0;t<j;t++) { res*=(str[t]-'0'); } dp[i][j]=res; } else if(i!=1) { int min=0x7FFFFFFF; for(int k=i-1;k<j;k++) { int temp=dp[i-1][k]*num(str,k+1,j); if(temp<min) min=temp; } dp[i][j]=min; } else if(i==1) { dp[i][j]=num(str,1,j); } } cout<<dp[4][len]<<endl; return 0; }
相关文章推荐
- DP--数字拆分成4段,怎样使得4段的乘积最小。
- 5.数字拆分成4段,怎样使得4段的乘积最小【dp】
- 数字拆分成4段,怎样使得4段的乘积最小
- 【POJ 1651】【区间DP 矩阵链乘的变形】Multiplication Puzzle【一串数字,除了头尾不能动,每次取个数字,它与左右相邻数字的乘积为其价值,求价值和最小】
- 输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。
- 【codeforces 721D】【贪心 堆】D. Maxim and Array 【给出n个数,k次机会,每次使得任意一个数字减少或者加上x,使得最后的乘积最小,最后的n个数大小】
- 输入一个递增排序的数组和一个数字S,在数组中查找两个数,是的他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的。
- 剑指offer——和为s的两个数字且乘积最小
- (Relax 贪心1.4)POJ 2325 Persistent Numbers(使用贪心策略解决这么一个问题: 给定一个数n,求一个最小的数m,使得m的各位的乘积==n)
- 给出一个整数N要求出一个最小正整数Q,使其各个数字的乘积正好等于N
- 【ProjectEuler】ProjectEuler_052(找出最小的正整数x,使得2x, 3x, 4x, 5x和6x都包含同样的数字)
- 请问如果我有字符串 “300,500,600-700”用JAVASCRIPT怎样才能拆分这个字符串,取得数字300 500 600 和700
- 在整数中删除数字,使得余下的数字按原次序组成的新数最小
- 一个n位的数,去掉其中的k位,问怎样去使得留下来的(n-k)位数按原来的前后顺序组成的数最小
- [BZOJ4037][HAOI2015]数字串拆分(矩阵+DP)
- poj 1032 拆分数字使乘积最大
- 在整数中删除数字,留下4个,使得余下的数字按原次序组成的新数最小
- hdu 3183 A Magic Lamp(给一个n位的数,从中删去m个数字,使得剩下的数字组成的数最小(顺序不能变),然后输出)
- 在整数n=742683613984中删除8个数字,使得余下的数字按原次序组成的新数最小(不含0)
- 水仙花数的算法(怎样怎样将数字拆分为个位,十位,百位)