列表

详情


NC219651. StopCounting!

描述

The Martingale casino is creating new games to lure in new gamblers who tire of the standard fare. Their latest invention is a fast-paced game of chance called Stop Counting!, where a single customer plays with a dealer who has a deck of cards. Each card has some integer value.

One by one, the dealer reveals the cards in the deck in order, and keeps track of the sum of the played cards and the number of cards shown. At some point before a card is dealt, the player can call "Stop Counting!" After this, the dealer continues displaying cards in order, but does not include them in the running sums. At some point after calling "Stop Counting!", and just before another card is dealt, the player can also call "Start Counting!" and the dealer then includes subsequent cards in the totals. The player can only call "Stop Counting!" and "Start Counting!" at most once each, and they must call "Stop Counting!" before they can call "Start Counting!". A card is "counted" if it is dealt before the player calls "Stop Counting!" or is dealt after the player calls "Start Counting!"

The payout of the game is then the average value of the counted cards. That is, it is the sum of the counted cards divided by the number of counted cards. If there are no counted cards, the payout is 0.

You have an 'in' with the dealer, and you know the full deck in order ahead of time. What is the maximum payout you can achieve?

输入描述

The first line of the input contains a single integer , the number of cards in the deck.

The second line of input contains  space-separated integers, the values on the cards. The value of each card is in the range . The cards are dealt in the same order they are given in the input.

输出描述

Output the largest attainable payout. The answer is considered correct if the absolute error is less than , or the relative error is less than .

示例1

输入:

5
10 10 -10 -4 10

输出:

10.000000000

示例2

输入:

4
-3 -1 -4 -1

输出:

0.000000000

原站题解

上次编辑到这里,代码来自缓存 点击恢复默认模板

Python3(3.9) 解法, 执行用时: 1602ms, 内存消耗: 130652K, 提交时间: 2021-03-22 22:15:10

read=lambda:map(int,input().split())
a,=read()
save=[*read()]
pre=[]
suf=[]
tot=0
for each in save:
    tot+=each
    pre.append((tot)/(len(pre)+1))
save.reverse()
tot=0
for each in save:
    tot+=each
    suf.append((tot)/(len(suf)+1))
res=0.0000
for i in range(len(pre)):
    res=max(res,max(suf[i],pre[i]))
print("%.9f\n"%res)

C++(clang++11) 解法, 执行用时: 180ms, 内存消耗: 8188K, 提交时间: 2021-05-10 20:36:21

#include<stdio.h>
double a[1001234];
int main()
{
	int n,i,j;
	double sum=0;
	scanf("%d",&n);
	double maxx=0;
	for(i=1;i<=n;i++)
	{
		scanf("%lf",&a[i]);
		sum+=a[i];
		if(sum/i>maxx)
		maxx=sum/i;
	}
	sum=0;
	for(i=n;i>=1;i--)
	{
		sum+=a[i];
		if(sum/(n-i+1)>maxx)
		maxx=sum/(n-i+1);
	}
	printf("%.9lf\n",maxx);
 } 

上一题