ACM-ICPC(10/23)
贪心
区间相关问题
选择不相交区间:
hdu 2037
给定一些区间,选择尽量多的区间,他们互相不交叉。(活动安排问题)
分析:贪心思路是解决活动安排问题的好方案。
按照区间右端点排序,从前往后遍历,给后面的选择留出更多的时间。
#include <bits/stdc++.h>
using namespace std;
struct Node {
int l,r;
bool operator < (const Node & rhs) const {
return r < rhs.r;
}
}nodes[];
int n;
int main()
{
while(scanf("%d",&n),n) {
for(int i = ; i < n; i++) scanf("%d%d",&nodes[i].l,&nodes[i].r);
sort(nodes,nodes+n);
int pos = nodes[].r;
int ans = ;
for(int i = ; i < n; i++) {
if(nodes[i].l>=pos) {
ans ++;
pos = nodes[i].r;
}
}
printf("%d\n",ans);
}
return ;
}
区间选点
数轴上有n个闭区间,取尽量少的点,使得每个区间内都至少有一个点(pku 3485)
多年前写的代码了~
#include <cstdio>
#include <cmath>
#include <algorithm>
using namespace std;
const int maxn = ;
struct Point {
double x,y;
} points[maxn];
struct Line {
double x,y;
} lines[maxn];
bool cmp(Line a,Line b) {
return a.y < b.y;
}
int main()
{
double s;
double d;
while(~scanf("%lf%lf",&s,&d)) {
int n;
scanf("%d",&n);
for(int i=; i<n; i++) {
scanf("%lf%lf",&points[i].x,&points[i].y);
lines[i].x = points[i].x - sqrt(d*d-points[i].y*points[i].y);
lines[i].y = points[i].x + sqrt(d*d-points[i].y*points[i].y);
}
sort(lines,lines+n,cmp);
int ans = ;
double cur = lines[].y;
for(int i=; i<n; i++) {
if(cur>=lines[i].x&&cur<=lines[i].y)
continue;
else {
cur = lines[i].y;
ans++;
}
}
printf("%d\n",ans);
}
return ;
}
区间覆盖问题
数轴上有n个闭区间,选择尽量少的区间去覆盖一条指定线段[s,t]。紫书P233。
扫描线
https://nanti.jisuanke.com/t/17309
题意:有N个站台,每个站台有一些人要上车,上车的人是从某一站台到某一个站台[l,r]区间,有w个人,求最少安排多少个位置。
此题是个大坑货~之前WA了,一直以为我的扫描线写错了,原来是一个排序因子,当时间相等时,先下车再上车。
#include <bits/stdc++.h>
using namespace std;
struct Node {
int l,w,flag;
bool operator < (const Node & rhs) const {
if(l!=rhs.l) return l < rhs.l;
else return flag < rhs.flag;
}
};
int main()
{
int n;
while(scanf("%d",&n),n) {
int l,r,w;
vector<Node> v;
for(int i = ; i < n; i++) {
scanf("%d%d%d",&l,&r,&w);
v.push_back(Node{l,w,});
v.push_back(Node{r,w,-});
}
sort(v.begin(),v.end());
int ans = ;
int tmp = ;
for(int i = ; i < *n; i++) {
if(v[i].flag==) {
tmp += v[i].w;
ans = max(ans,tmp);
}
else {
tmp -=v[i].w;
}
}
printf("%d\n",ans);
}
puts("*");
return ;
}
扫描法
相比于扫描线还是很简单的,不过还是主要看思路。
uva 11054
题意:有n 个酒庄,有的酒庄需要货,有的酒庄卖货, 将一单位的酒从一个地方放到相邻地方耗费1;
求平衡供需关系的最小花费。
对于一号酒庄,他要等于0,那么一定是从2号搬进,或者搬出去。这样就有子问题产生了。
扫描法和普通枚举,在于要维护一些重要的值,简化计算。
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int main() {
int n;
while(scanf("%d",&n),n) {
ll ans = ,a,last = ;
for(int i = ; i < n; i++) {
cin>>a;
ans += abs(last);
last +=a;
}
cout<<ans<<endl;
}
return ;
}
ACM-ICPC(10/23)的更多相关文章
- hduoj 4715 Difference Between Primes 2013 ACM/ICPC Asia Regional Online —— Warmup
http://acm.hdu.edu.cn/showproblem.php?pid=4715 Difference Between Primes Time Limit: 2000/1000 MS (J ...
- 2015 ACM / ICPC 亚洲区域赛总结(长春站&北京站)
队名:Unlimited Code Works(无尽编码) 队员:Wu.Wang.Zhou 先说一下队伍:Wu是大三学长:Wang高中noip省一:我最渣,去年来大学开始学的a+b,参加今年区域赛之 ...
- 2017 ACM/ICPC Asia Regional Qingdao Online
Apple Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)Total Submi ...
- ACM/ICPC 之 BFS(离线)+康拓展开(TSH OJ-玩具(Toy))
祝大家新年快乐,相信在新的一年里一定有我们自己的梦! 这是一个简化的魔板问题,只需输出步骤即可. 玩具(Toy) 描述 ZC神最擅长逻辑推理,一日,他给大家讲述起自己儿时的数字玩具. 该玩具酷似魔方, ...
- ACM ICPC 2015 Moscow Subregional Russia, Moscow, Dolgoprudny, October, 18, 2015 D. Delay Time
Problem D. Delay Time Input file: standard input Output file: standard output Time limit: 1 second M ...
- hduoj 4712 Hamming Distance 2013 ACM/ICPC Asia Regional Online —— Warmup
http://acm.hdu.edu.cn/showproblem.php?pid=4712 Hamming Distance Time Limit: 6000/3000 MS (Java/Other ...
- hduoj 4707 Pet 2013 ACM/ICPC Asia Regional Online —— Warmup
http://acm.hdu.edu.cn/showproblem.php?pid=4707 Pet Time Limit: 4000/2000 MS (Java/Others) Memory ...
- hduoj 4706 Children's Day 2013 ACM/ICPC Asia Regional Online —— Warmup
http://acm.hdu.edu.cn/showproblem.php?pid=4706 Children's Day Time Limit: 2000/1000 MS (Java/Others) ...
- 2016 ACM/ICPC Asia Regional Qingdao Online 1001/HDU5878 打表二分
I Count Two Three Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- 2016 ACM/ICPC Asia Regional Shenyang Online 1009/HDU 5900 区间dp
QSC and Master Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) ...
随机推荐
- 安装Samba服务让宿主机和虚拟机共享文件
安装 samba 服务器之后,很方便的实现 Windows 和 Linux 进行通信. 安装步骤: 1 .在 Ubuntu 系统下面安装 samba 服务: $ sudo apt-get instal ...
- enum学习
https://www.cnblogs.com/hyl8218/p/5088287.html
- 【3dsMax安装失败,如何卸载、安装3dMax 2012?】
AUTODESK系列软件着实令人头疼,安装失败之后不能完全卸载!!!(比如maya,cad,3dsmax等).有时手动删除注册表重装之后还是会出现各种问题,每个版本的C++Runtime和.NET f ...
- 【温故知新】c#抽象类abstract与接口interface
1.什么是抽象类 先来看MSDN对抽象类描述: 抽象类是一些留有部分或全部成员未实现的类,以便可以由派生类来提供实现. 在面向对象的编程中,抽象类用作层次结构的基类,并表示不同对象类型组的通用功能. ...
- java与C语言在字符串结束符上的区别
综述:在C语言中字符串或字符数组最后都会有一个额外的字符‘\0’来表示结束,而在java语言中没有结束符这一概念.具体见下面分析. 1. C 语言 在C语言中字符串和字符数组基本上没有区别,都需要结束 ...
- 用 Python 构建 web 应用
用 Python 构建 web 应用 如果说仅仅要用 Python 构建 web 应用,可以将 socket 连接.HTTP 原始请求和响应格式等涉及网络基础的东西交给现成的库来实现,只需要专注于 w ...
- VueConf 全球首届Vue.js开发者大会资料整理
最近一直关注VueConf全球首届Vue.js开发者大会,现在将此次开发者大会资料整理如下: 一.Vue 2017 现状与展望 [尤雨溪] 在线视频: PPT整理: Vue 2017 现状与展望 ...
- Thrift笔记(一)--Hello Demo
Thrift是一个RPC框架 1. 用IDL定义好实体和服务框架,如实体字段名,类型等.服务名,服务参数,返回值等 2. 通过编译器或者说代码生成器生成RPC框架代码 IDL语法,代码生成器的安装使用 ...
- stark——查看页面编辑删除按钮
一.数据列表 设计查页面,主要展示两部分内容,表头部分和数据部分, 表头通过遍历list_display和默认要显示的编辑和删除字段. 1.数据构建 (1)service/stark.py,后台数据构 ...
- 【数据库】8.0 MySQL入门学习(八)——创建并使用数据库、获得数据库和表的信息
1.0 使用SHOW语句找出服务器上当前存在什么数据库: mysql> SHOW DATABASES; 每台机器上的数据库列表是不同的,但是很可能有mysql和test数据库.mysql是必需的 ...