原题链接:蓝桥杯算法提高-能量项链
解题思路:
为了可以得到能量的最大值,最为简单的思路即为将最小的数字放在两数字的中间被吃掉,逐渐过滤掉最小的数字,最终得到能量总值便是最大值。
以样例输入为例子:
2 3 5 10
得到其中最小的数字为 2,要将它吃掉,先通过10 - 2 - 3的组合,将 2 这个数字吃掉。得到此时释放的能量为:10*2*3 = 60,数据形式变为:
0 3 5 10 (被吃掉的数用0替代)
得到其中除 0 以外的最小数字为 3,将它吃掉,通过10 - 3 - 5这样的组合即可。得到此时释放的能量为:10 * 3 * 5 = 150,数据形式变为:
0 0 5 10
同上述理,通过组合10 - 5 - 10的组合把 5 吃掉就可以了,释放能量 10 * 5 * 10 = 500,数据形式变为:
0 0 0 10
一共进行了 4 - 1 的讨论,类推出像这样形式的分析需要进行N-1次。
参考代码:
#include <stdio.h> int main() { int n, An[200]; scanf("%d", &n); for(int i = 0; i < n; i ++) scanf("%d", &An[i]); int TheMin = An[0], pos, sum = 0; for(int i = 0; i < n - 1; i ++){ // 进行 N - 1次讨论 int TheRight, TheLeft, temp1, temp2; // pos用来标记最小值的所在位置不宜改动,使用两个临时变量 temp1, temp2 辅助向左向右寻找非零值 for(int j = 0; j < n; j ++){ if( !An[j] ) continue; if(TheMin >= An[j]){ pos = j; TheMin = An[j]; } } // 寻找数列中除了 0 以外的最小值 temp1 = pos; for(int t = 1; t < n; t ++){ if(temp1 + t == n) temp1 -= n; if( An[temp1 + t] != 0 ) TheRight = An[temp1 + t]; } // 从最小值的标记位开始向右寻找除了 0 以外的值 temp2 = pos; for(int t = 1; t < n; t ++){ if(temp2 - t == -1) temp2 += n; if( An[temp2 - t] != 0 ) TheLeft = An[temp2 - t]; } // 从最小值的标记位开始向左寻找除了 0 以外的值 sum += TheLeft * TheMin * TheRight; // 得到该次分析所释放的能量 TheMin = TheLeft; An[pos] = 0; // 将变量初始化 } printf("%d", sum); return 0; }
若有改进,欢迎与我讨论٩(˃̶͈̀௰˂̶͈́)و
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复