作业一——根据成绩计算出至少需要发多少奖金才能让所有的组满意。

简介: 狐进行了一次黑客马拉松大赛,全公司一共分为了N个组,每组一个房间排成一排开始比赛,比赛结束后没有公布成绩,但是每个组能够看到自己相邻的两个组里比自己成绩低的组的成绩,比赛结束之后要发奖金,以1w为单位,每个组都至少会发1w的奖金,另外,如果一个组发现自己的奖金没有高于比自己成绩低的组发的奖金,就会不满意,作为比赛的组织方,根据成绩计算出至少需要发多少奖金才能让所有的组满意。
 
 

输入描述:

 
 

输出描述:

 
 

示例1

输入

 
 

输出

 
 

思路:

1、先给结果数组(用于记录每支队伍的奖金值的数组)赋初值为1.

2、然后从左往右遍历队伍,如果后面的比前面的成绩好,则将该队伍的值修改为前一个队伍的奖金值+1;

3、然后从后往前遍历,如果后一个比前一个的分值低,但是奖金高,则将前一个队伍的奖金值改为后一个队伍的奖金+1.

4、遍历记录奖金的数组,获取奖金总额。

#include<iostream>
#include<vector>
using namespace std;

int minMoney(vector<int> teams){
	if(teams.size()<=0) return 0;
	
	vector<int>money(teams.size(),1);
	int sum=0;
	for(int i=1; i<teams.size(); i++){
		if(teams[i]>teams[i-1]) 
			money[i]=money[i-1]+1;
	}

	for(int i=teams.size()-1;i>=0;i--){
		if(teams[i]<teams[i-1]){
			if(money[i]>=money[i-1])
				money[i-1]=money[i]+1;
		}
	}
    
	for(int i=0; i<teams.size(); i++)
		sum+=money[i];
    
	return sum;
}

int main(){
	int N=0, temp=0;
	vector<int>teams;
	cin>>N;
	while(N--){
		cin>>temp;
		teams.push_back(temp);
	}

	int answer=minMoney(teams);
    cout<<answer;
	return 0;
}

 

 

相关文章
|
8月前
|
算法 前端开发
在既定时间做作业的学生人数
在既定时间做作业的学生人数
59 0
|
7月前
1077 互评成绩计算 (20 分)
1077 互评成绩计算 (20 分)
|
7月前
|
SQL 算法 大数据
深入解析力扣181题:超过经理收入的员工(自连接方法详解及模拟面试问答)
深入解析力扣181题:超过经理收入的员工(自连接方法详解及模拟面试问答)
|
8月前
|
SQL
leetcode-SQL-1731. 每位经理的下属员工数量
leetcode-SQL-1731. 每位经理的下属员工数量
63 0
|
8月前
leetcode-857:雇佣 K 名工人的最低成本
leetcode-857:雇佣 K 名工人的最低成本
61 0
|
8月前
|
SQL 数据挖掘 数据处理
「SQL面试题库」 No_99 顾客的可信联系人数量
「SQL面试题库」 No_99 顾客的可信联系人数量
【SQL开发实战技巧】系列(十四):计算消费后的余额&计算银行流水累计和&计算各部门工资排名前三位的员工
本篇文章讲解的主要内容是:***通过模拟计算消费流水账及计算银行流水累计和讲解sum()over()函数使用场景、通过计算各部门工资排名前三位的员工小案例来介绍ROW_NUMBER、RANK、DENSE_RANK使用方法及区别***
【SQL开发实战技巧】系列(十四):计算消费后的余额&计算银行流水累计和&计算各部门工资排名前三位的员工
(未解决)leetcode857 雇佣k名工人的最低成本
(未解决)leetcode857 雇佣k名工人的最低成本
79 0
|
移动开发
文科生成为技术经理,一共分几步(1)?
文科生成为技术经理,一共分几步(1)?
180 0
文科生成为技术经理,一共分几步(1)?
|
机器学习/深度学习 缓存 Kubernetes
文科生成为技术经理,一共分几步(2)?
文科生成为技术经理,一共分几步(2)?
183 0
文科生成为技术经理,一共分几步(2)?

热门文章

最新文章