2019nc#9
| 题号 | 标题 | 已通过代码 | 题解/讨论 | 通过率 | 团队的状态 |
|---|---|---|---|---|---|
| A | The power of Fibonacci | 点击查看 | 进入讨论 | 69/227 | 未通过 |
| B | Quadratic equation | 点击查看 | 高次剩余 | 391/888 | 未通过 |
| C | Inversions of all permutations | 点击查看 | 进入讨论 | 28/61 | 未通过 |
| D | Knapsack Cryptosystem | 点击查看 | 进入讨论 | 606/2251 | 通过 |
| E | All men are brothers | 点击查看 | 进入讨论 | 425/1117 | 通过 |
| F | Birthday Reminders | 点击查看 | 进入讨论 | 5/11 | 未通过 |
| G | Checkers | 点击查看 | 进入讨论 | 0/15 | 未通过 |
| H | Cutting Bamboos | 点击查看 | 二分,主席树 | 187/834 | 通过 |
| I | KM and M | 点击查看 | 进入讨论 | 19/296 | 未通过 |
| J | Symmetrical Painting | 点击查看 | 进入讨论 | 227/930 | 通过 |
H Cutting Bamboos
这道题用主席树过的,记录下区间权值。
// #pragma GCC optimize(2)
// #pragma GCC optimize(3)
// #pragma GCC optimize(4)
#include <algorithm>
#include <iterator>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <iomanip>
#include <bitset>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <stack>
#include <cmath>
#include <queue>
#include <list>
#include <map>
#include <set>
#include <cassert>
#include <unordered_map>
// #include<bits/extc++.h>
// using namespace __gnu_pbds;
using namespace std;
#define pb push_back
#define fi first
#define se second
#define debug(x) cerr<<#x << " := " << x << endl;
#define bug cerr<<"-----------------------"<<endl;
#define FOR(a, b, c) for(int a = b; a <= c; ++ a) typedef long long ll;
typedef unsigned long long ull;
typedef long double ld;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll; const int inf = 0x3f3f3f3f;
const ll inff = 0x3f3f3f3f3f3f3f3f;
const int mod = 1e9+; template<typename T>
inline T read(T&x){
x=;int f=;char ch=getchar();
while (ch<''||ch>'') f|=(ch=='-'),ch=getchar();
while (ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
return x=f?-x:x;
}
/**********showtime************/ const int N = 2e5 + , M = 4e6 + ;//M为节点个数,为Q*log(N)
int root[N], lson[M], rson[M], value[M], tot = ;
ll sum[M];
const double eps = 1e-;
//建树
void build(int &x, int l, int r) {
x = ++tot;
value[x] = ;
sum[x] = ;
if(l == r) {
return ;
}
int m = (l+r) >> ;
build(lson[x], l, m);
build(rson[x], m+, r);
value[x] = value[lson[x]] + value[rson[x]];
}
// 将某个历史版本p位置的值加v
void update(int old, int &x, int p, int v, int l, int r) {
x = ++tot;
lson[x] = lson[old], rson[x] = rson[old], value[x] = value[old] + v, sum[x] = sum[old] + p;
if(l == r) return ;
int m = (l+r) >> ;
if(p <= m) update(lson[x], lson[x], p, v, l, m);
else update(rson[x], rson[x], p, v, m+, r);
}
//访问某个历史版本L到R的区间和
int query(int L, int R, int x, int l, int r) {
if(L <= l && r <= R) return value[x];
int m = (l+r) >> , ans = ;
if(L <= m) ans += query(L, R, lson[x], l, m);
if(R > m) ans += query(L, R, rson[x], m+, r);
return ans;
}
ll query2(int L, int R, int x, int l, int r) {
if(L <= l && r <= R) return sum[x];
int m = (l+r) >> ;
ll ans = ;
if(L <= m) ans += query2(L, R, lson[x], l, m);
if(R > m) ans += query2(L, R, rson[x], m+, r);
return ans;
}
const int maxn = 2e5+;
ll pre[maxn], a[maxn];
double cal(double val, int L, int R) {
int hi = floor(val);
int cnt = query(, hi, root[R], , ) - query(, hi, root[L-], , );
double ss = (R - L + - cnt) * val;
ss += 1.0*query2(, hi,root[R], , ) - query2(, hi, root[L-], , );
return ss;
}
int main(){
int n,m;
scanf("%d%d", &n, &m);
build(root[], , );
for(int i=; i<=n; i++) {
scanf("%lld", &a[i]), pre[i] = pre[i-] + a[i];
update(root[i-], root[i], a[i], , , );
}
while(m--) {
int L, R, x, y;
scanf("%d%d%d%d", &L, &R, &x, &y);
ll ss = pre[R] - pre[L-];
double nd = ss*1.0 / y *(y - x);
double le = , ri = , res = ;
//debug(nd);
while(le + eps < ri) {
double mid = (le + ri) / ;
if(cal(mid, L, R) <= nd) le = mid, res = mid;
else ri = mid;
}
printf("%.10f\n", res);
}
return ;
}
J Symmetrical Painting
题意:
有n个矩形,宽度都为1,排列在坐标轴上,问消去一些矩形的一部分,使得原来的图形上下对称。这个对称图形最大可能面积。
思路:
有点类似扫描线的做法。
/*
* @Author: chenkexing
* @Date: 2019-08-16 15:34:14
* @Last Modified by: chenkexing
* @Last Modified time: 2019-08-16 15:41:12
*/ // #pragma GCC optimize(2)
// #pragma GCC optimize(3)
// #pragma GCC optimize(4)
#include <algorithm>
#include <iterator>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <iomanip>
#include <bitset>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <stack>
#include <cmath>
#include <queue>
#include <list>
#include <map>
#include <set>
#include <cassert>
// #include<bits/extc++.h>
// using namespace __gnu_pbds;
using namespace std;
#define pb push_back
#define fi first
#define se second
#define debug(x) cerr<<#x << " := " << x << endl;
#define bug cerr<<"-----------------------"<<endl;
#define FOR(a, b, c) for(int a = b; a <= c; ++ a) typedef long long ll;
typedef long double ld;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll; const int inf = 0x3f3f3f3f;
const ll inff = 0x3f3f3f3f3f3f3f3f;
const int mod = ; template<typename T>
inline T read(T&x){
x=;int f=;char ch=getchar();
while (ch<''||ch>'') f|=(ch=='-'),ch=getchar();
while (ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
return x=f?-x:x;
} /**********showtime************/
const int maxn = ;
pii a[maxn * ]; int main(){
int n;
scanf("%d", &n);
int tot = ;
for(int i=; i<=n; i++) {
int le,ri;
scanf("%d%d", &le, &ri);
// 在底,中点,高上有可能取到极值。
a[++tot] = pii(*le, );
a[++tot] = pii(le + ri, -);
a[++tot] = pii(*ri, );
}
sort(a+, a++tot);
ll ans = , sum = ;
ll cnt = a[].se;
for(int i=; i<=tot; i++) {
sum += cnt * (a[i].fi - a[i-].fi);
ans = max(ans, sum);
cnt += a[i].se;
}
printf("%lld\n", ans);
return ;
}
2019nc#9的更多相关文章
- 2019nc#2
A Eddy Walker 题意 你有n个点(0-n-1),按顺序形成一个环,初始时你在0的位子,你随机顺时针走一步或者逆时针走一步, 一旦你走到一个点后,环上所有点都被经过至少一次后,你就必须停下来 ...
- 2019nc#10
题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A Blackjack 点击查看 背包DP 32/109 补好了 B Coffee Chicken 点击查看 进入讨论 738/2992 通过 ...
- 2019NC#8
题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A All-one Matrices 点击查看 单调栈+前缀和 326/2017 通过 B Beauty Values 点击查看 进入讨论 8 ...
- 2019nc#7
题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A String 点击查看 进入讨论 566/3539 通过 B Irreducible Polynomial 点击查看 规律 730/229 ...
- 2019nc#6
https://ac.nowcoder.com/acm/contest/886#question 题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A Garbage Classificatio ...
- 2019nc#5
题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A digits 2 点击查看 1017/2384 通过 B generator 1 点击查看 567/3692 通过 C generato ...
- 2019nc#4
题号 标题 已通过代码 题解 通过率 团队的状态 A meeting 点击查看 树直径 604/2055 B xor 点击查看 线段树维护线性基交 81/861 未通过 C sequence 点击 ...
- 2019nc#3
题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A Graph Games 点击查看 进入讨论 18/292 未通过 B Crazy Binary String 点击查看 1107/3615 ...
- 2019NC#1
LINK B Integration 题意: 给定$a_1,a_2,...,a_n$, 计算 $$\frac{1}{π}\int_{0}^{\infty}\frac{1}{\prod\limits_{ ...
随机推荐
- kudu集群高可用搭建
首先咱得有KUDU安装包 这里就不提供直接下载地址了(因为有5G,我 的服务器网卡只有4M,你们下的很慢) 这里使用的是CDH版本 官方下载地址http://archive.cloudera.com/ ...
- 【Android】Error:Execution failed for task ':app:lint'
详细信息如下: Error:Execution failed for task ':app:lint'. > Lint found errors in the project; aborting ...
- 100天搞定机器学习|Day13-14 SVM的实现
昨天我们学习了支持向量机基本概念,重申数学推导原理的重要性并向大家介绍了一篇非常不错的文章.今天,我们使用Scikit-Learn中的SVC分类器实现SVM.我们将在day16使用kernel-tri ...
- Linux 常见的常识及常用快捷键方式
1. ,请写出linux系统中常见一级目录的名称及作用. /root : 超级用户的家目录 /home: 普通用户的家目录 /boot: 启动目录,启动相关文件(系统内核启动文件) /de ...
- 后端小白的VUE入门笔记, 前端高能慎入
因为项目需要前后端分离,后端竟然不用控制view层了,页面的跳转后端不再干涉,(前端的vue经过打包后成了一张index.html) 后端只需要响应给前端json串就ok,其实这不是爽歪歪?但是觉得还 ...
- 简易数据分析 09 | Web Scraper 自动控制抓取数量 & Web Scraper 父子选择器
这是简易数据分析系列的第 9 篇文章. 今天我们说说 Web Scraper 的一些小功能:自动控制 Web Scraper 抓取数量和 Web Scraper 的父子选择器. 如何只抓取前 100 ...
- C#开发可播放摄像头及任意格式视频的播放器
前言 本文主要讲述,在WPF中,借助Vlc.DotNet调用VLC类库,实现视频播功能,下面我们先来做开发前的准备工作. 准备工作 首先,我们创建一个项目WpfVLC,然后,进入Neget搜索Vlc. ...
- 偏差和方差以及偏差方差权衡(Bias Variance Trade off)
当我们在机器学习领域进行模型训练时,出现的误差是如何分类的? 我们首先来看一下,什么叫偏差(Bias),什么叫方差(Variance): 这是一张常见的靶心图 可以看左下角的这一张图,如果我们的目标是 ...
- Windows Server 2008 R2服务器内存使用率过高,但与任务管理器中进程占用内存和不一致
系统环境: Windows Server 2008 R2 + Sql Server 2008 R2 问题描述: Windows Server 2008 R2系统内存占用率过大,而在任务管理器中各进 ...
- 危险的Hystrix线程池
本文介绍Hystrix线程池的工作原理和参数配置,指出存在的问题并提供规避方案,阅读本文需要对Hystrix有一定的了解. 文本讨论的内容,基于hystrix 1.5.18: <dependen ...