P2345 [USACO04OPEN] MooFest G
简单的一个分块处理:优雅的暴力枚举
#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的更多相关文章
- luoguP5094 [USACO04OPEN]MooFest 狂欢节
get 到的 这种需要求 含 max 的式子,枚举最大值的方法非常普遍. 类似的,还有含 min , gcd 的式子,枚举他们也很普遍 主要难点 我们首先想到,先按 v 从小到大排序,因为这样既可以简 ...
- Storyboards Tutorial 03
这一节主要介绍segues,static table view cells 和 Add Player screen 以及 a game picker screen. Introducing Segue ...
- 文件图标SVG
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink ...
- 洛谷 P2345 奶牛集会 解题报告
P2345 奶牛集会 题目背景 MooFest, 2004 Open 题目描述 约翰的N 头奶牛每年都会参加"哞哞大会".哞哞大会是奶牛界的盛事.集会上的活动很 多,比如堆干草,跨 ...
- [转]Linux下g++编译与使用静态库(.a)和动态库(.os) (+修正与解释)
在windows环境下,我们通常在IDE如VS的工程中开发C++项目,对于生成和使用静态库(*.lib)与动态库(*.dll)可能都已经比较熟悉,但是,在linux环境下,则是另一套模式,对应的静态库 ...
- CentOS 6.6 升级GCC G++ (当前最新版本为v6.1.0) (完整)
---恢复内容开始--- CentOS 6.6 升级GCC G++ (当前最新GCC/G++版本为v6.1.0) 没有便捷方式, yum update.... yum install 或者 添加y ...
- Linux deepin 下sublimes配置g++ openGL
参考 :http://blog.csdn.net/u010129448/article/details/47754623 ubuntu 下gnome只要将代码中deepin-terminal改为gno ...
- [翻译svg教程]svg 中的g元素
svg 中的<g>元素用来组织svg元素.如果一组svg元素被g元素包裹了,你可以通过对g元素进行变换(transform),被g元素包裹的元素也将被变换,就好这些被svg包裹的元素是一个 ...
- 软件工程:黄金G点小游戏1.0
我们要做的是黄金G点小游戏: N个同学(N通常大于10),每人写一个0~100之间的有理数 (不包括0或100),交给裁判,裁判算出所有数字的平均值,然后乘以0.618(所谓黄金分割常数),得到G值. ...
- 2016huasacm暑假集训训练五 G - 湫湫系列故事——减肥记I
题目链接:http://acm.hust.edu.cn/vjudge/contest/126708#problem/G 这是一个01背包的模板题 AC代码: #include<stdio.h&g ...
随机推荐
- vue-vite-ts 新版
Vue 后台管理系统 一.系统创建 1.1.环境检测 $ node -v v18.10.0 $ npm -v 9.1.2 ## 若没有该命令 需要用 npm install -g pnpm 安装 $ ...
- (一)REDIS之常见数据结构及操作
(一)基本数据结构 1.1 String结构: String底层结构是动态字符串,可修改指定位置数据,通过预分配冗余空间减少内存的频繁分配,实际分配的空间capacity一般要高于实际字符串长度len ...
- HDLbits——Exams/2014 q4b
题目要求 使用verilog描述如图所示得移位寄存器: Write a top-level Verilog module (named top_module) for the shift regist ...
- stream 链式结构
Double totalPaymentAmount = Optional.ofNullable(wayfairMonthBill.getPaymentAmountDetailJson()) .filt ...
- SAP 内外交货单过账
* 交货单过账 DATA: LS_HEADER_DATA TYPE BAPIIBDLVHDRCON, LS_HEADER_CONTROL TYPE ...
- 51nod1355
没啥意思的板子题. 首先,众所周知, \[\gcd\{f_a,f_b\}=f_{\gcd\{a,b\}} \] 所以考虑将 \(\operatorname{lcm}\) 转化为 \(\gcd\). \ ...
- 4. 模板解析,生成render函数,渲染页面
解析模板,生成render函数,执行render函数,实现视图渲染 1.模板转化成ast语法树 2.ast语法树生成render函数 3.执行render函数生成虚拟dom 4.执行_update方法 ...
- QFramework UI 笔记(后续不断 直到UKitI篇结束)
1.所有的UIElement 传消息给 UIPanel 时,必须先注册 SendEvent(); RegisterEvent(); 2.注意Unity直接生成控件的名称,命名带(1)之类的 ...
- Navicat连接Oracle时报错ORA-28547:完美解决
1. 先用你的IDEA或者别人的连接到oracle数据库(为了查询版本) 1.1 查询版本SQL:select * from v$version; 2. 引入对应的oci.dll文件 链接:https ...
- 12. Redis 安装
参考http://www.runoob.com/redis/redis-install.html Window 下安装 下载地址:https://github.com/MSOpenTech/redis ...