c++编程大师挑战赛-魔法棒

魔法棒

暂无标签

题目统计 全部提交

时间限制:C/C++ 1000MS,其他语言 2000MS

内存限制:C/C++ 256MB,其他语言 512MB

难度:简单

出题人:admin

描述

2、Master在给他的伙伴Sandy准备礼物。他有一个包含n个数的数列a,这个礼物就是数列中所有元素的乘积。Master想让这个乘积尽可能的大,他有一个魔法棒,可以使得其中任意一个数增大1,但是可惜的是这个魔法棒只能使用1次,聪明的你能帮助Master使用这个魔法棒,使得对于魔法棒改变后的新数列,Master能获得最大的乘积吗?

输入描述

第1行包含一个正整数n,表示这个数列包含的数的个数(1<= n <=9)

第2行包含n个数,表示该数列中的每一个数ai(0<= ai <=9),任意两个数之间用空格分割

输出描述

输出一行,表示使用魔法棒后,Master所能获得的最大乘积

用例输入 1

复制代码
4
2 2 1 2

用例输出 1

复制代码
16

思路:

我们仔细看,这里的n和ai是很小的,所以,我们只要用一种很笨很暴力的方法就能做出来了

我们放一个循环,每次给一个ai++,然后把n个数都乘起来,最后看那一次最大就好了


代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	long long n,ma=INT_MIN;//INT_MIN就是int能表示的最小值,也就是-2147483648左右
	cin>>n;//n个数
	long long a[n+10];
	for(int i=1;i<=n;i++){
		cin>>a[i];//读入n个数
	}
	for(int i=1;i<=n;i++){
		a[i]++;//实用魔法棒
		long long cj=1;//乘积
		for(int j=1;j<=n;++j){
			cj*=a[j];//都乘起来
		}
		if(cj>ma){//如果比之前的数大
			ma=cj;//那最大的就是cj
		}
		a[i]--;//要减回去,变成原来的数字
	}
	cout<<ma;//输出
	return 0;
}
相关推荐
散峰而望7 小时前
【算法竞赛】C++函数详解:从定义、调用到高级用法
c语言·开发语言·数据结构·c++·算法·github
CoderCodingNo7 小时前
【GESP】C++五级真题(贪心思想考点) luogu-B4071 [GESP202412 五级] 武器强化
开发语言·c++·算法
我有一些感想……7 小时前
An abstract way to solve Luogu P1001
c++·算法·ai·洛谷·mlp
智者知已应修善业8 小时前
【求等差数列个数/无序获取最大最小次大次小】2024-3-8
c语言·c++·经验分享·笔记·算法
..过云雨9 小时前
17-2.【Linux系统编程】线程同步详解 - 条件变量的理解及应用
linux·c++·人工智能·后端
量子炒饭大师10 小时前
Cyber骇客的逻辑节点美学 ——【初阶数据结构与算法】二叉树
c语言·数据结构·c++·链表·排序算法
fpcc10 小时前
C++编程实践—false_type和true_type的实践应用
c++
量子炒饭大师10 小时前
Cyber骇客神经塔尖协议 ——【初阶数据结构与算法】堆
c语言·数据结构·c++·二叉树·github·
王老师青少年编程11 小时前
2025年12月GESP(C++二级): 环保能量球
c++·算法·gesp·csp·信奥赛·二级·环保能量球
CoderCodingNo11 小时前
【GESP】C++五级真题(贪心思想考点) luogu-P11960 [GESP202503 五级] 平均分配
开发语言·c++·算法