HDU2037 贪心 动归均可+证明
|
动归:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct node
{
int s;
int t;
}node;
node a[10001];
int F[25];
int cmp(const void *i,const void *j)
{ node *ii=(node *)i,*jj=(node *)j;
if(ii->t!=jj->t)
return ii->t-jj->t;
else
return ii->s-jj->s;
}
int max(int a,int b)
{
if(a>b) return a;
else return b;
}
int main()
{
freopen("a.in","r",stdin);
freopen("a.out","w",stdout);
int n,i,j;
while(scanf("%d",&n)!=EOF&&n!=0)
{
memset(F,0,sizeof(F));
memset(a,0,sizeof(a));
for(i=1;i<=n;i++)
scanf("%d%d",&a[i].s,&a[i].t);
qsort(a+1,n,sizeof(a[1]),cmp);
j=1;
for(i=0;i<=100;i++)
{
if(i!=0)
F[i]=F[i-1];
for(;j<=n;j++)
{
if(a[j].t<i) {continue;}
if(a[j].t>i) {break;}
F[i]=max(F[i],F[a[j].s]+1);
}
}
printf("%d\n",F[100]);
}
return 0;
}
贪心证明(利用数学归纳法):
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct node
{
int s;
int t;
}node;
node a[10001];
int ans=0;
int cmp(const void *i,const void *j)
{ node *ii=(node *)i,*jj=(node *)j;
if(ii->t!=jj->t)
return ii->t-jj->t;
else
return ii->s-jj->s;
}
int max(int a,int b)
{
if(a>b) return a;
else return b;
}
int main()
{
freopen("a.in","r",stdin);
freopen("b.out","w",stdout);
int n,i,j,end;
while(scanf("%d",&n)!=EOF&&n!=0)
{
ans=0;end=0;
memset(a,0,sizeof(a));
for(i=1;i<=n;i++)
scanf("%d%d",&a[i].s,&a[i].t);
qsort(a+1,n,sizeof(a[1]),cmp);
for(i=1;i<=n;i++)
{
if(a[i].s>=end)
ans++,end=a[i].t;
}
printf("%d\n",ans);
}
return 0;
}
HDU2037 贪心 动归均可+证明的更多相关文章
- CF2B The least round way(贪心+动规)
题目 CF2B The least round way 做法 后面\(0\)的个数,\(2\)和\(5\)是\(10\)分解质因数 则把方格中的每个数分解成\(2\)和\(5\),对\(2\)和\(5 ...
- [HDU2037]贪心入门
今年暑假不AC Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Sub ...
- HDU6438 Buy and Resell 解题报告(一个有趣的贪心问题的严格证明)
写在前面 此题是一个很容易想到的贪心题目,但是正确性的证明是非常复杂的.然而,目前网上所有题解并未给出本题贪心算法的任何正确性证明,全部仅停留在描述出一个贪心算法.本着对算法与计算机科学的热爱(逃), ...
- The - Modcrab——使用贪心策略
一.题目信息 The - Modcrab 简单翻译一下:Vova有生命值h1,每次攻击值为a1,每瓶药水恢复生命值c1;Modcrab有生命值h2,每次攻击值为a2.在每个关卡开始,Vova有两种选择 ...
- noip知识点总结之--贪心
一.什么是贪心 贪心算法嘛... 就是在对某个问题求解时,总是做出在当前看来是最好的选择 In other wors,并不是从整体最优上加以考虑,而是在获得某种意义上的局部最优解 二.贪心算法的适用前 ...
- 最大公约数(gcd):Euclid算法证明
1个常识: 如果 a≥b 并且 b≤a,那么 a=b. 2个前提: 1)只在非负整数范围内讨论两个数 m 和 n 的最大公约数,即 m, n ∈ N. 2)0可以被任何数整除,但是0不能整除任何数,即 ...
- 剑指Offer——贪心算法
剑指Offer--贪心算法 一.基本概念 所谓贪心算法是指,在对问题求解时,总是做出在当前看来是最好的选择.也就是说,不从整体最优上加以考虑,他所做出的仅是在某种意义上的局部最优解.虽然贪心算法不能对 ...
- 【贪心算法】POJ-3040 局部最优到全局最优
一.题目 Description As a reward for record milk production, Farmer John has decided to start paying Bes ...
- CodeForcesdiv1:995C - Leaving the Bar(随机算法+贪心)
For a vector →v=(x,y)v→=(x,y), define |v|=√x2+y2|v|=x2+y2. Allen had a bit too much to drink at the ...
随机推荐
- StaggeredGridView+universal-image-loader载入网路图片实现瀑布流
StaggeredGridView 开源lib https://github.com/maurycyw/StaggeredGridView 文章demo下载地址 http://download.c ...
- 改进的简单Tooltips显示
使用js简单改进了Tooltips的显示效果,可进一步使用CSS对改进的Tooltips进行美化. 前台布局代码: <asp:Panel ID="Panel1" runat= ...
- CSS筛选器简单实例1
1.通配符 <!--筛选器---通配符实例--> <!--支持IE7+ --> <style type="text/css"> *.all { ...
- mvc原理和mvc模式的优缺点
一.mvc原理 mvc是一种程序开发设计模式,它实现了显示模块与功能模块的分离.提高了程序的可维护性.可移植性.可扩展性与可重用性,降低了程序的开发难度.它主要分模型.视图.控制器三层. 1.模型 ...
- 如何利用自己的电脑做服务器发布tomcat的WEB项目供外网访问
1.首先你要确定你有一个外网ip地址.如果你分配到的是一个局域网IP地址需要经过一系列的转换为外网ip地址,然后继续下面操作. 2.拿到外网IP地址,进行tomcat的server.xml文件的配置. ...
- Java—Integer类
Integer类 Integer 类在对象中包装了一个基本类型 int 的值.Integer 类型的对象包含一个 int 类型的字段. 该类提供了多个方法,能在 int 类型和 String 类型之间 ...
- Linux命令查询手册--sort
一.sort的工作原理 sort将文件的每一行作为一个单位,相互比较,比较原则是从首字符向后,依次按ASCII码值进行比较,最后将他们按升序输出. 二.sort的参数选项 1. sort -u 在输出 ...
- thinkphp3.2之模型(M层)
最近学习了php框架thinkphp,回头总结了些学习心得知识,希望对大家有帮助 1.模型的概念: 模型(Model)是 ThinkPHP 中一个很重要的概念,粗略的理解模型就是与数据库交互信息进行c ...
- 【转】生产环境MySQL Server核心参数的配置
⑴ lower_case_table_names ● 推荐理由 GNU/Linux 平台,对数据库.表.存储过程等对象名称大小 ...
- Windows中安装Emacs
首先从http://gnu.org/software/emacs中下载window下的压缩包,然后解压..运行ROOT/bin/addpm.exe进行安装. 将鼠标右键添加Emacs编辑: 1. 打开 ...