土题大战Vol.0 A. 笨小猴 思维好题
土题大战Vol.0 A. 笨小猴 思维好题
题目描述
驴蛋蛋有 \(2n + 1\) 张 \(4\) 星武器卡片,每张卡片上都有两个数字,第 \(i\) 张卡片上的两个数字分别是 \(A_i\) 与 \(B_i\)。
现在驴蛋蛋要从所有卡片中选出恰好 \(n + 1\) 张卡片,然后计算他选出的所有卡片中 \(A_i\) 的和与 \(B_i\) 的和。他的目的是要使他选出的卡片的\(A_i\) 的和与 \(B_i\) 的和,都要分别大于剩下 \(n\) 张没选的卡片的 \(A_i\) 的和与 \(B_i\) 的和。
驴蛋蛋最近沉迷于周年挑战赛,所以他希望你能帮他解决这个问题。
输入格式
输入第一行是一个整数 \(n\),意义如以上所示。
接下来有 \(2n + 1\) 行,每行为两个正整数,第 \(i\) 行的两个正整数分别代表 \(A_i\) 和 \(B_i\)。
输出格式
如果无法选出 \(n + 1\) 张卡片满足驴蛋蛋的要求,输出一个数 \(-1\)。
否则输出 \(n + 1\) 行,每 行有一个正整数,表示选出的卡片编号(从 \(1\) 开始)。如果有多解,输出任意一组解均可
样例
样例输入
2
4 2
9 4
5 3
7 5
8 1
样例输出
3
4
2
样例解释
选择顺序随意,选择第二,三,四张三张卡片,\(A\)的总和为\(21\),\(B\)的总和为\(12\),均大于剩下的卡片\(A\),\(B\)之和。
数据范围与提示
共\(10\)组测试数据
对于前\(3\)组测试数据有第\(p\)组中\(N=2 \times p+1\)
对于后7组测试数据有第\(p\)组中\(N=p\times 10000\)
对所有测试数据\(1 \leq A_i,B_i \leq 10^9\)
如果你通过某种方法\(hack\)掉了评测插件,你可以申请获得该测试点的分数\(=ω=\)
分析
先画一个图便于理解
我们先按照\(B\)的值从小到大排序,把序列中的最后一个元素单独拿出来选上,剩下的两两一组
在两两一组中,我们选取\(A\)的值较大的那一个,这样我们就可以把\(A\)元素的条件满足
对于\(B\)元素来说,我们选择的元素的差值是图中红色的部分
我们会发现,在最坏的情况下,红色部分拼起来的总和也不会超过最后一个元素的\(B\)值
也就是说,我们选择的\(B\)元素的值一定大于剩下的\(B\)元素的值
所以,我们只需要简单排序即可
代码
#include<bits/stdc++.h>
using namespace std;
const int maxn=1e6+5;
typedef long long ll;
ll pja,pjb;
struct asd{
ll xx,yy;
int bh;
}b[maxn];
bool cmp(asd aa,asd bb){
return aa.yy<bb.yy;
}
int n,m,top,sta[maxn];
int main(){
scanf("%d",&n);
m=n*2+1;
for(int i=1;i<=m;i++){
scanf("%lld%lld",&b[i].xx,&b[i].yy);
b[i].bh=i;
}
sort(b+1,b+1+m,cmp);
m--;
for(int i=1;i<=m;i+=2){
if(b[i].xx>b[i+1].xx) sta[++top]=b[i].bh;
else sta[++top]=b[i+1].bh;
}
sta[++top]=b[m+1].bh;
for(int i=1;i<=top;i++){
printf("%d\n",sta[i]);
}
return 0;
}
土题大战Vol.0 A. 笨小猴 思维好题的更多相关文章
- 金题大战Vol.0 A、凉宫春日的叹息
金题大战Vol.0 A.凉宫春日的叹息 题目描述 给定一个数组,将其所有子区间的和从小到大排序,求第 \(k\) 小的是多少. 输入格式 第一行两个数\(n\),$ k\(,表示数组的长度和\)k$: ...
- 金题大战Vol.0 B、序列
金题大战Vol.0 B.序列 题目描述 给定两个长度为 \(n\) 的序列\(a\), \(b\). 你需要选择一个区间\([l,r]\),使得\(a_l+-+a_r>=0\)且\(b_l+-+ ...
- 金题大战Vol.0 C、树上的等差数列
金题大战Vol.0 C.树上的等差数列 题目描述 给定一棵包含\(N\)个节点的无根树,节点编号\(1-N\).其中每个节点都具有一个权值,第\(i\)个节点的权值是\(A_i\). 小\(Hi\)希 ...
- 火题大战Vol.0 B 计数DP
火题大战Vol.0 B 题目描述 \(n\) 个沙茶,被编号 \(1\)~$ n$.排完队之后,每个沙茶希望,自己的相邻的两人只要无一个人的编号和自己的编号相差为 \(1\)(\(+1\) 或\(-1 ...
- 水题大战Vol.3 B. DP搬运工2
水题大战Vol.3 B. DP搬运工2 题目描述 给你\(n,K\),求有多少个\(1\)到\(n\) 的排列,恰好有\(K\)个数\(i\) 满足\(a_{i-1},a_{i+1}\) 都小于\(a ...
- 火题大战Vol.1 A.
火题大战Vol.1 A. 题目描述 给定两个数\(x\),\(y\),比较\(x^y\) 与\(y!\)的大小. 输入格式 第一行一个整数\(T\)表示数据组数. 接下来\(T\)行,每行两个整数\( ...
- noip2008 笨小猴
P1125 笨小猴 1.6K通过 3.7K提交 题目提供者该用户不存在 标签模拟2008NOIp提高组 难度普及- 提交该题 讨论 题解 记录 题目描述 笨小猴的词汇量很小,所以每次做英语选择题的 ...
- [TYVJ] P1010 笨小猴
笨小猴 背景 Background NOIP2008复赛提高组第一题 描述 Description 笨小猴的词汇量很小,所以每次做英语选择题的时候都很头疼.但是他找到了一种方法,经试验证明,用这种 ...
- 洛谷-笨小猴-NOIP2008提高组复赛
题目描述 Description 笨小猴的词汇量很小,所以每次做英语选择题的时候都很头疼.但是他找到了一种方法,经试验证明,用这种方法去选择选项的时候选对的几率非常大! 这种方法的具体描述如下:假设m ...
随机推荐
- [redis] -- 为什么那么快
1 完全基于内存 2 数据结构简单,对数据操作也简单 3 只有单线程,避免了不必要的上下文切换,也不存在竞态,不存在多进程或多线程导致的切换而消耗CPU,不用开了各种锁的问题 4 使用多路IO复用模型 ...
- Zabbix-server自动发现,批量添加主机,并链接模板
zabbix可以手动添加agent客户端,当主机数量比较多时,这时手工重复工作会大大增加.zabbix的自动发现功能可以帮我们解决这个问题. 准备条件: 1. 被监控主机都装上zabbix-agent ...
- 虚拟机 NAT 网络静态ip配置记录
环境 VMware 15.5.5 build-16285975 centos7 虚拟网络编辑器配置 位置 编辑 --> 虚拟网络编辑器 示例 以下以 192.168.18.0 网段ip为例,实际 ...
- python学习笔记1 -- 面向对象编程高级编程1
说起高级其实也就是些基础的东西,但是活用和熟用肯定会大幅度提升代码质量 首先要记录的是面向对象的灵活性,及如何去控制其灵活性,她允许你在实例中新增属性和方法,允许你给类新增属性和方法,也支持在定义类时 ...
- Python日历模块
Python日历模块 calendar: 0:星期一是第一天 6:星期日是最后一天 注:形参 w,I,c 可以不写,正常使用,使用默认形参即可 calendar(year,w=2,I=1,c=6): ...
- 探讨Netty获取并检查Websocket握手请求的两种方式
在使用Netty开发Websocket服务时,通常需要解析来自客户端请求的URL.Headers等等相关内容,并做相关检查或处理.本文将讨论两种实现方法. 方法一:基于HandshakeComplet ...
- Sharding-JDBC主键生成策略
当使用分库分表等功能之后,就不能再依赖数据库自带的主键生成机制了,一方面主键ID不能重复,另外需要在新增之前就知道主键ID,才能保证ID能够均匀分布到不同的数据库或数据表中,所以要使用一个合理的主键生 ...
- 使用ajax发送的请求实现页面跳转
ajax 本身是不适用于页面跳转的: 可以借助其他方法实现: 1,window.location.href = "/home"; 2,springMVC 返回的modelAndVi ...
- 使用opencv在Qt控件上播放mp4文件
文章目录 简介 核心代码 运行结果 简介 opencv是一个开源计算机视觉库,功能非常多,这里简单介绍一下OpenCV解码播放Mp4文件,并将图像显示到Qt的QLabel上面. 核心代码 头文件 #i ...
- “随手记”开发记录day12
就我们团队昨天的讨论,今天进行更改. 今天我们先简单的更改了之前的粉色背景图,因为用户反应总览界面的“总览”二字,是深粉色背景不太美观.进过多次更改之后使颜色变得更舒适.