• C. Annoying Present SB题


    C. Annoying Present
    time limit per test
    2 seconds
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    Alice got an array of length nn as a birthday present once again! This is the third year in a row!

    And what is more disappointing, it is overwhelmengly boring, filled entirely with zeros. Bob decided to apply some changes to the array to cheer up Alice.

    Bob has chosen mm changes of the following form. For some integer numbers xx and dd, he chooses an arbitrary position ii (1in1≤i≤n) and for every j[1,n]j∈[1,n] adds x+ddist(i,j)x+d⋅dist(i,j) to the value of the jj-th cell. dist(i,j)dist(i,j) is the distance between positions ii and jj (i.e. dist(i,j)=|ij|dist(i,j)=|i−j|, where |x||x| is an absolute value of xx).

    For example, if Alice currently has an array [2,1,2,2][2,1,2,2] and Bob chooses position 33 for x=1x=−1 and d=2d=2 then the array will become [21+22, 11+21, 21+20, 21+21][2−1+2⋅2, 1−1+2⋅1, 2−1+2⋅0, 2−1+2⋅1] = [5,2,1,3][5,2,1,3]. Note that Bob can't choose position ii outside of the array (that is, smaller than 11 or greater than nn).

    Alice will be the happiest when the elements of the array are as big as possible. Bob claimed that the arithmetic mean value of the elements will work fine as a metric.

    What is the maximum arithmetic mean value Bob can achieve?

    Input

    The first line contains two integers nn and mm (1n,m1051≤n,m≤105) — the number of elements of the array and the number of changes.

    Each of the next mm lines contains two integers xixi and didi (103xi,di103−103≤xi,di≤103) — the parameters for the ii-th change.

    Output

    Print the maximal average arithmetic mean of the elements Bob can achieve.

    Your answer is considered correct if its absolute or relative error doesn't exceed 10610−6.

    Examples
    input
    Copy
    2 3
    -1 3
    0 0
    -1 -4
    output
    Copy
    -2.500000000000000
    input
    Copy
    3 2
    0 2
    5 0
    output
    Copy
    7.000000000000000

    这题分析一下题目 就是对d的正负进行分类讨论
      d>=0 则选择 i=1; 反之 i=(n+1)/2;
      代码量也特别少

      
     1 #include <bits/stdc++.h>
     2 using namespace std;
     3 const int maxn = 1e5 + 10;
     4 const int INF = 0x3fffffff;
     5 typedef long long LL;
     6 using namespace std;
     7 LL n, m, x, d, ans = 0;
     8 int main() {
     9     scanf("%lld%lld", &n, &m);
    10     for (int i = 0 ; i < m ; i++) {
    11         scanf("%lld%lld", &x, &d);
    12         if (d >= 0)    ans += n * x + d * (n - 1) * n / 2;
    13         else    ans += n * x + d * (n - (n + 1) / 2) * ((n + 1) / 2);
    14     }
    15     printf("%.8f
    ", 1.0 * ans / n);
    16     return 0;
    17 }
  • 相关阅读:
    数学思维 | 数学错觉-少了的一块钱
    windows | 换行符 | windows换行符号和Unix换行符
    Windows | Hosts | windows hosts简介
    WIndows | windows网页打开速度慢,修改DNS
    Apache-shiro的内置Realm之jdbcRealm
    Apache-shiro的内置Realm之iniRealm
    快速理解shiro的授权
    快速理解shiro的认证
    SpringBoot2.x整合Shiro权限认证项目搭建
    Apache shiro权限控制流程和常见的概念
  • 原文地址:https://www.cnblogs.com/qldabiaoge/p/9311730.html
Copyright © 2020-2023  润新知