题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=1170
http://115.159.40.116/problem_show.php?pid=5696
http://115.159.40.116/problem_show.php?pid=5696
题目描述
小明和小红在打赌说自己数学学的好,于是小花就给他们出题了,考考他们谁NB,题目是这样的给你N个数
在这n个数之间添加N-1个*或+,使结果最大,但不可以打乱原顺序,请得出这个结果
如
1 3 5
结果是(1+3)*5=20;最大
可以添加若干个括号,但一定要保证配对,但是每两个数之间只可能有一个*或+
数列最前和最后不应有+或乘
小明想赢小红但是他比较笨,请你帮帮他
输入
多组测试数据以EOF结束,每组有一个n(n<10000),然后有n个正整数a[i](1<=a[i]<=20)
输出
输出最大的结果由于结果比较大,结果对10086取余
样例输入
3 1 2 3 3 5 1 2
样例输出
9 15
/*题目炸看上去挺复杂,又是+*又是可以加括号的。
其实找几组数一算发现只有出现1的地方需要用加法,
ps:至于怎么加、加在哪可自行思考
先在数组中扫一遍1,同时先计算加法(相当于添加括号)
然后累乘即可
我的程序需要注意几组特殊数据
1
1
12
1 1 1 1 1 1 1 1 1 1 1 1
4
2 1 1 2
答案分别是
1
81
9
*/
#include <stdio.h>
int main() {
int n, num[10005], i;
while(~scanf("%d", &n)) {
num[0] = 21, num[n+1] = 21;
for(i = 1; i <= n; i++) scanf("%d", &num[i]);
if(n > 1) {//考虑特殊数据
for(i = 1; i <= n; i++) {
if(num[i] == 1) { /*考虑特殊数据*/
if(num[i-1] <= num[i+1] || (num[i-1]==2&&num[i+1]==1)) {
num[i] += num[i-1];
num[i-1] = 1;
} else {
num[i+1]++;
i++;//只是为了减少一些不必要的循环
}
}
}
}
for(i = 2; i <= n; i++) num[1] = (num[1]*num[i])%10086;
printf("%d\n", num[1]);
}
return 0;
}