简单的一个分块处理:优雅的暴力枚举

#include<bits/stdc++.h>
using namespace std;

typedef long long ll;
const int N = 2e4 + 7;

int st[N];
struct Block {
  int l, r;
  ll sum, m;
} block[151];
struct Node {
  ll v, x;
} a[N];
bool cmp ( Node x, Node y ) {
  if(x.v == y.v) return x.x < y.x;
  return x.v < y.v;
}

void build ( ll n ) {
  ll p = sqrt ( n );
  ll t = n/p;
  if( p * t < n ) t ++;
  for( int i = 1;i <= t;i ++ ) {
    block[i].l = ( i - 1 ) * p;
    block[i].r = i * p;
    block[i].m = block[i].sum = 0;
  }
  block[t].r = n;
}

ll find ( int q, ll n ) {
  ll ans = 0, sum = 0, m = 0;
  ll t = sqrt ( n );
  ll k = n / t;
  if(k * t < n) k ++;
  t = a[q].x / t + (a[q].x % t != 0); int p = 0;
  for( p = 1;p < t;p ++ )
    m += block[p].m, sum += block[p].sum;

  for( int j = block[t].l + 1;j < a[q].x;j ++ )
  if(st[j])
    m ++, sum += j;

  ans += a[q].v * ( m * a[q].x - sum );
  st[a[q].x] = 1;
  block[p].m ++, block[p].sum += a[q].x;

  m = sum = 0;
  for( int j = a[q].x + 1; j <= block[p].r;j ++ )
  if(st[j])
    m ++, sum += j;

  for( p += 1; p <= k; p ++ )
    m += block[p].m, sum += block[p].sum;
  ans += a[q].v * ( sum - m * a[q].x );
  return ans;
}

int main() {
  int n;
  ll ans = 0;
  scanf ( "%d", &n );
  ll maxx = 0;
  for(int i = 1;i <= n;i ++) {
    scanf ( "%lld%lld", &a[i].v, &a[i].x );
    maxx = max ( maxx, a[i].x );
  }
  build ( maxx );
  sort ( a + 1, a + n + 1, cmp );
  for( int i = 1;i <= n;i ++ )
    ans += find ( i, maxx );
  printf ( "%lld", ans );
  return 0;
}

P2345 [USACO04OPEN] MooFest G的更多相关文章

  1. luoguP5094 [USACO04OPEN]MooFest 狂欢节

    get 到的 这种需要求 含 max 的式子,枚举最大值的方法非常普遍. 类似的,还有含 min , gcd 的式子,枚举他们也很普遍 主要难点 我们首先想到,先按 v 从小到大排序,因为这样既可以简 ...

  2. Storyboards Tutorial 03

    这一节主要介绍segues,static table view cells 和 Add Player screen 以及 a game picker screen. Introducing Segue ...

  3. 文件图标SVG

    ​<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink ...

  4. 洛谷 P2345 奶牛集会 解题报告

    P2345 奶牛集会 题目背景 MooFest, 2004 Open 题目描述 约翰的N 头奶牛每年都会参加"哞哞大会".哞哞大会是奶牛界的盛事.集会上的活动很 多,比如堆干草,跨 ...

  5. [转]Linux下g++编译与使用静态库(.a)和动态库(.os) (+修正与解释)

    在windows环境下,我们通常在IDE如VS的工程中开发C++项目,对于生成和使用静态库(*.lib)与动态库(*.dll)可能都已经比较熟悉,但是,在linux环境下,则是另一套模式,对应的静态库 ...

  6. CentOS 6.6 升级GCC G++ (当前最新版本为v6.1.0) (完整)

    ---恢复内容开始--- CentOS 6.6 升级GCC G++ (当前最新GCC/G++版本为v6.1.0) 没有便捷方式, yum update....   yum install 或者 添加y ...

  7. Linux deepin 下sublimes配置g++ openGL

    参考 :http://blog.csdn.net/u010129448/article/details/47754623 ubuntu 下gnome只要将代码中deepin-terminal改为gno ...

  8. [翻译svg教程]svg 中的g元素

    svg 中的<g>元素用来组织svg元素.如果一组svg元素被g元素包裹了,你可以通过对g元素进行变换(transform),被g元素包裹的元素也将被变换,就好这些被svg包裹的元素是一个 ...

  9. 软件工程:黄金G点小游戏1.0

    我们要做的是黄金G点小游戏: N个同学(N通常大于10),每人写一个0~100之间的有理数 (不包括0或100),交给裁判,裁判算出所有数字的平均值,然后乘以0.618(所谓黄金分割常数),得到G值. ...

  10. 2016huasacm暑假集训训练五 G - 湫湫系列故事——减肥记I

    题目链接:http://acm.hust.edu.cn/vjudge/contest/126708#problem/G 这是一个01背包的模板题 AC代码: #include<stdio.h&g ...

随机推荐

  1. 2022-3-10内部群每日三题-清辉PMP

    1.一位项目经理得知,由于持续的罢工,该项目的进口设备尚未被海关放行.项目经理首先应该怎么做? A.执行定性风险分析 B.执行定量风险分析 C.与团队一起审查风险影响 D.实施风险应对计划 2.一位团 ...

  2. Yii2安装步骤

    通过 Composer 安装了半天一直网络报错,配置了镜像,又报错依赖,运行跳过依赖,这个命令还是报错,我裂开. 最后只能利用归档文件安装,1.下http://www.yiiframework.com ...

  3. 12. Redis 安装

    参考http://www.runoob.com/redis/redis-install.html Window 下安装 下载地址:https://github.com/MSOpenTech/redis ...

  4. monogo-shell

    创建集合 use person //创建数据库或进入数据库 db.createCollection(table_name) 主键 插入数据时会自动生成主键,保证每条数据唯一性 生成对象主键 > ...

  5. 3MP/5MPNetwork-Camera摄像头默认口令

    网络资产搜索: shodan: 找到5MP-Network-Carema 登陆:admin/a***n End!!!

  6. 在Unity3D中开发的Dissolve Shader

    Swordmaster Dissolve Shaders 特点 本插件共包含两种Dissolve Shader: (1).一种类型是Bumped Specular工作流的Dissolve Shader ...

  7. 【LeetCode - 1055】形成字符串的最短路径

    1.题目描述 代码: #include <iostream> #include <string> using namespace std; const int MAX_LETT ...

  8. java为什么要使用静态内部类

    参考:https://blog.csdn.net/fengyuyeguirenenen/article/details/122696650 static内部类意味着: (1) 为创建一个static内 ...

  9. obspy常用命令记录

    如何使用obspy(适用于MAC.Linux.Windows)完全替代SAC(使用于Linux和MAC) 波形预处理 # 去均值 stream.detrend('demean') # 去线性趋势 st ...

  10. IDEA 启动SpringBoot项目或Spring项目出现程序包XXX不存在

    该方法是在你的pom中的依赖(是否缺少,版本是否兼容)maven仓库等配置没有问题的情况下 第一种方法: 打开IDEA底部的终端Terminal,输入"mvn idea:idea" ...