【链接】 我是链接,点我呀:)

【题意】

在这里输入题意

【题解】

可以考虑把所有的题目按照ai排序。
然后顺序考虑最后做出来的题目个数和第i道题目的ai一样。
则1..i-1这些题目就没有用了。
值考虑i..n这些题目就可以了。
显然考虑ti最小的若干项。
使得它们的时间和我这个做法太麻烦了。。

另解1

我这种做法其实可以做得更好一点:

即枚举题目个数i从n递减到1

然后在一个集合中维护ai>=i的题目(只要枚举到第i个的时候,把ai==i的加入set里面就好了),然后保证集合的大小为i就可以了。

->如果大于k了,那么就把ti最大的那几个删掉,直到集合的大小为k

维护集合里面的题目的和就好。

另解2

二分最后的分数。

显然如果分数mid可以得到的话。

那么分数mid-1肯定也可以得到。

可以看出来有单调性。

【代码】

#include <bits/stdc++.h>
#define ll long long
using namespace std; const int N = 2e5; struct BI {
ll a[N + 10],b[N+10]; int lowbit(int x) {
return x&(-x);
} void add(int x,int y) {
while (x <= N) {
a[x] += y;
x += lowbit(x);
}
} void add2(int x,int y) {
while (x <= N) {
b[x] += y;
x += lowbit(x);
}
} ll sum(int x) {
int now = 0;
while (x > 0) {
now += a[x];
x -= lowbit(x);
}
return now;
} int sum2(int x) {
int now = 0;
while (x > 0) {
now += b[x];
x -= lowbit(x);
}
return now;
} ll get_sum(int l, int r) {
return sum(r) - sum(l - 1);
} int get_sum2(int l, int r) {
return sum2(r) - sum2(l - 1);
} }B; struct abc{
int a,t,idx;
}; bool cmp(abc a,abc b){
return a.a<b.a;
} bool cmp2(abc a,abc b){
return a.t<b.t;
} abc a[N+10],b[N+10];
int should[N+10];
multiset< int > myset;
bool bo[N+10];
int n,t; int main(){
#ifdef LOCAL_DEFINE
freopen("rush_in.txt", "r", stdin);
#endif
ios::sync_with_stdio(0),cin.tie(0);
cin >> n >> t;
for (int i = 1;i <= n;i++){
cin >> a[i].a >> a[i].t;
a[i].idx = i;
}
for (int i = 1;i <= n;i++) myset.insert(a[i].t); sort(a+1,a+1+n,cmp); for (int i = 1;i <= n;i++) b[i] = a[i];
sort(b+1,b+1+n,cmp2);
for (int i = 1;i <= n;i++){
should[b[i].idx] = i;
B.add(i,b[i].t);
B.add2(i,1);
} int ans = 0,index = -1;
for (int i = 1;i <= n;i++){
int num = a[i].a;
ll now = 0;
int j = 0;
int l = 1,r = n,temp = -1,temptot;
while (l <= r){
int mid = (l+r)>>1;
int cnt = B.get_sum2(1,mid);
ll tot = B.get_sum(1,mid);
if (cnt<=num && tot<=t){
temptot = cnt;
l = mid+1;
temp = mid;
}else{
r = mid - 1;
}
} if (temp!=-1){
if (temptot>ans) {
ans = temptot;
index = i;
}
} j = i;
int tt = should[a[i].idx];
B.add2(tt,-1);
B.add(tt,-a[i].t);
bo[a[i].idx] = true;
while (j+1<=n && a[j+1].a==a[i].a) {
j++;
bo[a[j].idx] = true;
int tt = should[a[j].idx];
B.add2(tt,-1);
B.add(tt,-a[j].t);
}
i = j;
}
cout << ans << endl;
cout << ans << endl;
if (index!=-1){
sort(a+index,a+1+n,cmp2);
for (int i = index;i <= index+ans-1;i++)
cout <<a[i].idx<<' ';
}
return 0;
}

【Hello 2018 D】Too Easy Problems的更多相关文章

  1. 【AGC 005F】Many Easy Problems

    Description One day, Takahashi was given the following problem from Aoki: You are given a tree with ...

  2. 【AGC005F】Many Easy Problems FFT 容斥原理

    题目大意 给你一棵树,有\(n\)个点.还给你了一个整数\(k\). 设\(S\)为树上某些点的集合,定义\(f(S)\)为最小的包含\(S\)的联通子图的大小. \(n\)个点选\(k\)个点一共有 ...

  3. 【AGC005F】Many Easy Problems (NTT)

    Description ​ 给你一棵\(~n~\)个点的树和一个整数\(~k~\).设为\(~S~\)为树上某些点的集合,定义\(~f(S)~\)为最小的包含\(~S~\)的联通子图的大小.\(~n~ ...

  4. 【AGC005F】Many Easy Problems

    Description 题目链接 对于每个\(k\),统计任选\(k\)个点作为关键点的"最小生成树"的大小之和 Solution 正向想法是枚举或者计算大小为\(x\).叶子数目 ...

  5. 【AGC005 F】Many Easy Problems

    神他吗一天考一道码农题两道 FFT(其实还是我推式子一窍不通) 题意 给你一棵 \(n\) 个点的树,再给你一个常数 \(k\). 设 \(S\) 为树上某些点的集合,定义 \(f(S)\) 为最小的 ...

  6. 【Hello 2018 C】Party Lemonade

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 处理出凑够2^j最少需要花费多少钱. 即试着把第i种物品买2^(j-i)个,看看会不会更便宜 记录在huafei[0..31]中 然 ...

  7. 【Hello 2018 B】Christmas Spruce

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 写个dfs看看是不是每个节点都有3个叶子节点就可以了. [代码] #include <bits/stdc++.h> us ...

  8. 【Hello 2018 A】 Modular Exponentiation

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 当a<b的时候 a%b==a 显然2^n增长很快的. 当2^n>=1e8的时候,直接输出m就可以了 [代码] #incl ...

  9. 【AtCoder】AGC005 F - Many Easy Problems 排列组合+NTT

    [题目]F - Many Easy Problems [题意]给定n个点的树,定义S为大小为k的点集,则f(S)为最小的包含点集S的连通块大小,求k=1~n时的所有点集f(S)的和取模92484403 ...

随机推荐

  1. php八大设计模式之策略模式

    策略模式提供一个虚拟的整体,根据不同的要求(参数)提供不同的"零件"(调用不同的"零件"实现不同的结果). <?php /** * 策略模式 * 跟工厂模 ...

  2. 初学javascript,写一个简单的阶乘算法当作练习

    代码如下: <script> var a = prompt("请输入值"); function mul(a){ if(a==1){ return 1; } return ...

  3. gcd步数

    题目描述 一个有趣的函数F(a,b),表示对于数对(a,b)调用辗转相除法的步数为多少 例如 (24,40)....0 (16,24).....1 (8,16).....2 (0,8)....3,即f ...

  4. [洛谷P3929]SAC E#1 - 一道神题 Sequence1

    题目大意:给你一串数列,问你能否改变1个数或不改,使它变成波动数列? 一个长度为n的波动数列满足对于任何i(1 <= i < n),均有: a[2i-1] <= a[2i] 且 a[ ...

  5. 【LeetCode-面试算法经典-Java实现】【057-Insert Interval(插入区间)】

    [057-Insert Interval(插入区间)] [LeetCode-面试算法经典-Java实现][全部题目文件夹索引] 原题 Given a set of non-overlapping in ...

  6. [Recompose] Merge RxJS Button Event Streams to Build a React Counter Component

    Combining input streams then using scan to track the results is a common scenario when coding with s ...

  7. JAVA爬虫Nutch、WebCollector的正则约束

    爬虫爬取时,须要约束爬取的范围. 基本全部的爬虫都是通过正則表達式来完毕这个约束. 最简单的,正则: http://www.xinhuanet.com/.* 代表"http://www.xi ...

  8. poj3169 差分约束系统

    题意: 从1到n,n个数,从左向右依次排列. 给定两种形式的约束条件: 1.xi与yi的最大距离为dk 2.xi与yi的最小距离为dk 问满足这些限定条件的情况下,数1和n的最大距离是多少?(若约束条 ...

  9. 八款常用的 Python GUI 开发框架推荐

    作为Python开发者,你迟早都会用到图形用户界面来开发应用.本文将推荐一些 Python GUI 框架,希望对你有所帮助,如果你有其他更好的选择,欢迎在评论区留言. Python 的 UI 开发工具 ...

  10. BZOJ1685: [Usaco2005 Oct]Allowance 津贴

    [传送门:BZOJ1685] 简要题意: 贝西工作勤勤恳恳,她每月向约翰索要C 元钱作为工资.约翰手上有不少钱,他一共有N 种面 额的钞票.第i 种钞票的面额记作Vi,约翰有Ki 张.钞票的面额设定是 ...