nyoj1170最大的数

题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=1170
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 
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;
}


你可能感兴趣的:(算法)