算式最大值

蓝桥杯校内赛 算式最大值

因为找不到OJ系统 直接记录原题

算式最大值

描述
给定:
1)N个正整数A1, A2, … AN;
2)P个加号+和Q个减号-; (P+Q=N-1)
3)K对括号()
请你使用全部整数、加减号和括号,组成一个合法的算式(A1~AN在算式中的顺序随意),使得算式的结果最大。
注意加减号只能作为二元运算符出现在算式中,不能作为正负号。
括号可以出现在算式最左和最右,例如(((1+2)))是合法的。
例如对于样例数据,(2-1)+3或3+(2-1)等都是结果最大的算式。
输入
第一行包含4个整数,N,P, Q和K。
第二行包含N个整数A1, A2, … AN。
2 ≤ N ≤ 100 P+Q+1=N 0 ≤ K ≤ 10
1 ≤ Ai ≤ 1000
输出
最大算式结果
样例输入
3 1 1 1
1 2 3
样例输出
4

因为找不到OJ有这道题,所以该贪心策略有可能有漏洞

题目本来是想让我们用搜索来做的,简化了另一题最大的算式,但是这题实际上有贪心策略来解;
然后比赛时候居然这题深搜也没做完。。所以这里是记录耻辱的地方
思路简述:把减号和括号活用成该种形式a-(b-c-d) -->a+c+d-b
然后把b作为最小值,这样排就是最大值了。要是无括号和无减号另算就得了

import java.util.Arrays;
import java.util.Scanner;
public class F {
	
	static int[] num = new int[105];
	
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		int p = sc.nextInt();
		int q = sc.nextInt();
		int k = sc.nextInt();
		int sum = 0;
		int min = 2000;
		for(int i = 0; i < n; i++) {
			num[i] = sc.nextInt();
			min = min > num[i] ? num[i] : min;
			sum+=num[i];
		}
		if(q == 0) {
			System.out.println(sum);
		}else {
			if(k == 0) {
				Arrays.sort(num, 0, n);
				for(int i = 0; i < q; i++)
					sum-=2*num[i];
			}else {
				sum-=2*min;
			}
			System.out.println(sum);
		}
		
	}

}

你可能感兴趣的:(蓝桥杯,蓝桥杯)