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) ...
随机推荐
- PIE SDK K-Means分类
1.算法功能简介 K-Means 算法的基本思想是:以空间中 k 个点为中心进行聚类,对最靠近他们的对象归类.通过迭代的方法,逐次更新各聚类中心的值,直至得到最好的聚类结果. 算法首先随机从数据集中选 ...
- vue filters过滤器的使用
说的很详细 https://www.w3cplus.com/vue/how-to-create-filters-in-vuejs.html
- java String类型转 java.sql.time类型
String[] timePhase = reservationRuleInDTO.getTimePhase().split(",");List<ReservationTim ...
- 学习javscript对象笔记(一)
对象(Objects) 对象属性值可以是除undefined值之外的任意值 1.对象字面量 a.{} b.new object(); 注意事项: 在对象字面量中,如果属性名是一个合法的javasc ...
- Linux 上安装 weblogic12C (静默安装) (一)
最近负责在linux上安装weblogic,客户说要安装最新的版本,版本号为 12.1.X(12.1.2,12.1.3).开始以为和旧版安装一样,使用控制台的方式,下载bin文件,然后一步步在cons ...
- TOJ 3660 家庭关系
描述 给定若干家庭成员之间的关系,判断2个人是否属于同一家庭,即2个人之间均可以通过这些关系直接或者间接联系. 输入 输入数据有多组,每组数据的第一行为一个正整数n(1<=n<=100), ...
- PHP流程控制之goto语句
goto 操作符可以用来跳转到程序中的另一位置.该目标位置可以用目标名称加上冒号来标记,而跳转指令是 goto 之后接上目标位置的标记.PHP 中的 goto 有一定限制,目标位置只能位于同一个文件和 ...
- 诠释JavaScript中的this
文章首发:http://www.cnblogs.com/sprying/p/3573456.html 使用this的几种场合 1. 执行函数时,判断函数是对象方法还是一个单独的函数?单独的函数this ...
- 一个不错的架构图:基于SpringCloud的微服务项目
https://github.com/hanlin5566/HJ-MicroService
- C# .net页面乱码
可在web.config中设置 <globalization requestEncoding="utf-8" responseEncoding="utf-8&quo ...