贪心

区间相关问题

选择不相交区间:

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)的更多相关文章

  1. 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 ...

  2. 2015 ACM / ICPC 亚洲区域赛总结(长春站&北京站)

    队名:Unlimited Code Works(无尽编码)  队员:Wu.Wang.Zhou 先说一下队伍:Wu是大三学长:Wang高中noip省一:我最渣,去年来大学开始学的a+b,参加今年区域赛之 ...

  3. 2017 ACM/ICPC Asia Regional Qingdao Online

    Apple Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total Submi ...

  4. ACM/ICPC 之 BFS(离线)+康拓展开(TSH OJ-玩具(Toy))

    祝大家新年快乐,相信在新的一年里一定有我们自己的梦! 这是一个简化的魔板问题,只需输出步骤即可. 玩具(Toy) 描述 ZC神最擅长逻辑推理,一日,他给大家讲述起自己儿时的数字玩具. 该玩具酷似魔方, ...

  5. 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 ...

  6. 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 ...

  7. 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 ...

  8. hduoj 4706 Children&#39;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) ...

  9. 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 ...

  10. 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) ...

随机推荐

  1. PIE SDK去相关拉伸

    1.算法功能简介 由于高度相关的数据集经常生成十分柔和的彩色图像,因此经常使用 去相关拉伸工具来体消除多光谱数据集中的高度相关性, 从而生成一幅色彩亮丽的彩色合成图像.去相关拉伸需要 3 个输入波段, ...

  2. ajax数据获取与传送

    function service_ajax(){ var migrate_style = $('#myTab').find('.active').attr('value'); //jquery获取页面 ...

  3. (五)html部分标签元素补充

    html标签元素十分的多,一次性掌握全部,那是不可能的,在后续的学习中,会不断补充标签元素... 1.行元素和块元素 行标签元素即是标签元素根据内容大小进行自适应,而不是占据一整行. 如<spa ...

  4. pwn 题GDB调试技巧和exp模板

    GDB分析ELF文件常用的调试技巧 gdb常用命令 首先是gbd+文件名 静态调试 ,gdb attach +文件名 动态调试 为了方便查看堆栈和寄存器 最好是安装peda插件 安装 可以通过pip直 ...

  5. struts2返回结果类型

    在action下还有result标签 1.result不只有name,其实还有type result返回类型在struts-default.xml默认的配置文件中有定义,可以看到有result-typ ...

  6. Django分页解析

    分页 django中实现管理数据分页的类位于 django.core.paginator.py中 Paginator类 对列表数据进行分页处理 对象 Paginator(Post.objects.al ...

  7. 一个基于Ionic3.x cordova的移动APP demo

    项目地址如遇网络不佳,请移步国内镜像加速节点 前端技术: Angular4.x + ionic3.x + cordova 项目运行: git clone git@github.com:EasyTuan ...

  8. 从零开始的全栈工程师——JS面向对象(复习)

    作用域 栈内存:js执行的环境堆内存:存放代码块的空间 存放方式 键值对形式存放 字符串的形式存放js在执行之前 浏览器会给他一个全局作用域叫window 每个作用域下都分为两个模块 一个是内存模块一 ...

  9. Spring MVC 参数必填项导致客户端报 HTTP 400 并且无法进入断点的问题

    1.问题 Spring MVC 在参数上设置了必填项,post 请求时报 HTTP 400 并且未进入断点,如将“年龄”设置为了必填项: @RequestParam( value="age& ...

  10. Linux - centos 7 mysql安装

    安装 CentOS Linux release 7.1.1503 (Core)下载地址链接:https://pan.baidu.com/s/1c2rWsbm 密码:5nrt #yum -y insta ...