题目大意:有若干头牛,每个牛有一个音量值,两头牛能互相听见对方说话需要发出两头牛中音量值较大者的音量*两头牛的距离的音量,求使任意两头牛都互相听见对方需要发出的音量总和。每头牛的音量值可以相同,但坐标不会相同。

思路:如果一个牛a的音量值,对总体所做的贡献为(音量值比它小的在它左侧的牛的数量*Xa-音量值比它小的在它左侧的牛的坐标和)*a的音量值+(音量值比它小的在它右侧的牛的坐标和-音量值比它小的在它右侧的牛的数量*Xa)*a的音量值。

先按每头牛的音量值进行排序,就可以统计出音量值比某头牛小的牛的个数,以及这些牛的坐标值之和。搞两个树状数组,第一个树状数组用来维护在一只牛左侧的音量值比它小的牛的个数,右侧的根据左侧的也容易求出。第二个树状数组维护一只牛左侧的音量值比它小的所有牛的坐标值之和,右侧的根据左侧的也容易求出。

按音量值从小到大遍历所有牛,对每个牛a,第一个树状数组更新add(Xa,1),表示第Xa位置多了1个牛,求音量值比它小的在它左侧的牛的数量则sum(Xa-1),第二个树状数组更新add(Xa,Xa),表示第Xa位置为坐标值和贡献了Xa,音量值比它小的在它左侧的牛的坐标和则sum(Xa-1)即可。

代码:

//POJ.1990
//Author: Prgl
#include<bits/stdc++.h>
using namespace std;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0) typedef long long ll;
typedef pair<int, int>P;
typedef vector<int>vec; #define INF 0x3f3f3f3f
const double EPS = 1e-18;
const int MOD = 1e9 + 7;
const int maxn = 2e4 + 1; struct BIT {
ll bit[maxn + 1] , n;
void init(int k) { memset(bit, 0, sizeof(bit)); n = k; }
ll sum(ll i)
{
ll s = 0;
while (i > 0)
{
s += bit[i];
i -= i & (-i);
} return s;
}
void add(ll i, ll x)
{
while (i <= n)
{
bit[i] += x;
i += i & (-i);
}
}
}; struct C {
C() = default;
C(int a, int b, int c = -1) :vol(a), x(b), id(c) { }
int vol, x, id;//id为按音量排序后的序号
}; int N;
C cow[20001];
BIT bt1, bt2;
ll xsum[20001]; bool cmp1(C a, C b)
{
return a.vol < b.vol;
} bool cmp2(C a, C b)
{
return a.x < b.x;
} void solve()
{
bt1.init(20001);
bt2.init(20001);
ll res = 0;
sort(cow, cow + N, cmp1);//按音量排序,序号即为所有音量小于它的牛的数量
cow[0].id = 0;
xsum[0] = 0;
for (int i = 1; i <= N; i++)
{
cow[i].id = i;//音量值相同的两头牛id会不同,从而所有音量小于它们的牛的数量也不同,不会出现重复统计的情况
xsum[i] = xsum[i - 1] + cow[i - 1].x;//所有音量小于牛i的所有牛的坐标之和
}
for (int i = 0; i < N; i++)
{
ll x = cow[i].x, vol = cow[i].vol, id = cow[i].id;
ll l = bt1.sum(x - 1);//该牛左侧音量小于它的牛的数量
ll r = id - l;//右侧的
bt1.add(x, 1);//坐标x位置更新1牛
bt2.add(x, x);//坐标x位置更新1牛的坐标值
ll sumf = bt2.sum(x - 1), sumb = xsum[id] - bt2.sum(x - 1); //sumf:该牛左侧音量小于它的牛的坐标之和,sumb:右侧的
res += (l - r) * x * vol + (sumb - sumf) * vol;
}
cout << res << endl;
} int main()
{
IOS;
cin >> N;
for (int i = 0; i < N; i++)
{
int vol, x;
cin >> vol >> x;
cow[i] = C(vol, x);
}
solve(); return 0;
}

POJ1990 题解的更多相关文章

  1. POJ1990:MooFest——题解

    http://poj.org/problem?id=1990 题目大意:定义一对在树轴上的点,每对点产生的值为两点权值最大值*两点距离,求点对值和. 显然n*n复杂度不行,我们需要用树状数组维护两个东 ...

  2. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  3. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  4. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  5. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  6. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  7. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  8. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  9. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

随机推荐

  1. gin中从reader读取数据数据

    package main import ( "fmt" "github.com/gin-gonic/gin" "net/http" &quo ...

  2. python操作MySQL--实例

    有一段时间,没更新,但这都不是自己懒惰的借口,希望自己能坚持下去: python可以操作MySQL 数据库,需要安装的是MySQL-python,并且实现读入excel表及生成excel 表,则需要x ...

  3. Power Apps 创建响应式布局

    前言 我们都知道Power Apps作为低代码平台,最大的优势就是各个设备之间的兼容性,尤其是自带的响应式布局,非常好用. 这不,我们就为大家分享一下,如何使用Power Apps画布应用,创建响应式 ...

  4. mybatis 原生写法创建项目

    一.创建全局文件 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configuratio ...

  5. MySQL 5.7.19 简易安装、卸载教程

    前言:传统的 exe 文件安装的MySQL,安装后特别难卸载,而且一旦处理不好,就容易出错,想再安装别的版本也不容易.因为这种方式的安装,虽然是不断的下一步,但是卸载的时候需要处理很多,在本文最后,有 ...

  6. 【C++】输入输出

    缓冲 C++ 的输入输出均通过缓冲区来实现.缓冲区主要是为了解决速度不匹配的问题. cin 阻塞输入.当输入缓存中无字符时则等待用户输入. 输入缓冲 输入缓冲是一种行缓冲.在输入数据只要没有碰到换行符 ...

  7. Redis学习笔记(二)redis 底层数据结构

    在上一节提到的图中,我们知道,可以通过 redisObject 对象的 type 和 encoding 属性.可以决定Redis 主要的底层数据结构:SDS.QuickList.ZipList.Has ...

  8. v76.01 鸿蒙内核源码分析(共享内存) | 进程间最快通讯方式 | 百篇博客分析OpenHarmony源码

    百篇博客分析|本篇为:(共享内存篇) | 进程间最快通讯方式 进程通讯相关篇为: v26.08 鸿蒙内核源码分析(自旋锁) | 当立贞节牌坊的好同志 v27.05 鸿蒙内核源码分析(互斥锁) | 同样 ...

  9. 记录常见的问题:encodeURICompnent 解码过程中出现空格 以及 第三方app中使用schema 唤起app

    window.location.href 跳转的时候使用了encodeURIComponent编码了部分参数,但是在第三方app中出现了编码过后的参数换行和空格的情况(部分第三方应用或者java程序) ...

  10. Html 项目使用自定义字体文件问题

    感谢大佬:https://zhidao.baidu.com/question/652711582735059245.html 1.首先在项目过程中新建文件夹fonts将准备好的ttf字体文件复制该文件 ...