当要求最小值时,((2-1) mod 10)×((4+3) mod 10)=1×7=7,要求最大值时,为((2+4+3) mod 10)×(-1 mod 10)=9×9=81。特别值得注意的是,无论是负数还是正数,对10取模的结果均为非负值。 丁丁请你编写程序帮他赢得这个游戏。
标签:
当要求最小值时,((2-1) mod 10)×((4+3) mod 10)=1×7=7,要求最大值时,为((2+4+3) mod 10)×(-1 mod 10)=9×9=81。特别值得注意的是,无论是负数还是正数,对10取模的结果均为非负值。 丁丁请你编写程序帮他赢得这个游戏。
4 2 4 3 -1 2
7 81
#include<cstdio> #include<cstring> #include<algorithm> using namespace std; const int inf = 43333; const int MAX = 100; int dp1[MAX][MAX],dp2[MAX][MAX],sum[MAX]; int n,m; int min1,max1; int DP(int *a) { for(int i = 1 ; i <= n; i++) sum[i] = sum[i-1] + a[i]; for(int i = 0; i <= n ;i++){ for(int j = 0; j <= m ;j++){ dp1[i][j] = 0; dp2[i][j] = inf; } } dp1[0][0] = dp2[0][0] = 1; for(int i = 1 ; i <= n ;i++) dp1[i][1] = dp2[i][1] = (sum[i]%10+10)%10; for(int j = 2; j <= m ;j++){ for(int k = j; k <= n ;k++){ for(int p = j-1; p < k; p++){ dp1[k][j] = max(dp1[k][j],dp1[p][j-1]*(((sum[k]-sum[p])%10+10)%10)); dp2[k][j] = min(dp2[k][j],dp2[p][j-1]*(((sum[k]-sum[p])%10+10)%10)); } } } max1 = max(max1,dp1[n][m]); min1 = min(min1,dp2[n][m]); } int main() { int a[120]; while(~scanf("%d%d",&n,&m)){ min1 = inf; max1= 0; memset(sum,0,sizeof(sum)); for(int i = 1 ; i <= n ;i++){ scanf("%d",a+i); a[i+n] = a[i]; } for(int i = 0 ; i < n;i++) DP(a+i); printf("%d\n%d\n",min1,max1); } return 0; }
标签:
原文地址:http://www.cnblogs.com/zero-begin/p/4372881.html