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 ...
随机推荐
- 获取对象类型(swift)
获取对象类型(swift) by 伍雪颖 let date = NSDate() let name = date.dynamicType println(name) let string = &quo ...
- EffectiveC#03--用委托表示回调,用事件定义对外接口
1.回调的场景:我给了儿子一个任务且他可以报告状态来(重复的)打断我.而我在等待他完成任务的每一个部份时不用阻塞我自己的进程.他可以在有重要(或者事件)状态报告时,可以定时的打断我,或者向我询求帮助 ...
- 如何在WP8模拟器中连接本地的web服务
这个问题困扰了很久,查找答案一度找偏方向. 其实连接web服务对于wp7不是问题,因为wp7使用的网络就是本机的网络,但是到了wp8模拟器,纯粹的虚拟机,独立的设备,也就有了自己的网络连接,要当做虚拟 ...
- ASP.NET中的Request和Respone对象的使用
前台<body>中的表单代码: ASP.NET对象有如下几个: 本文从“asp.net中通过from表单submit提交到后台的实例”来谈谈Request和Response ...
- Installing the Eclipse Plugin
Installing the Eclipse Plugin Android offers a custom plugin for the Eclipse IDE, called Android Dev ...
- mssql 判断sql语句的执行效率语句
SET STATISTICS io ONSET STATISTICS time ONgo--========此处为sql代码段=============== select zxbh from t_yr ...
- BlockingQueue
BlockingQueue的使用 http://www.cnblogs.com/liuling/p/2013-8-20-01.html BlockingQueue深入分析 http://blog.cs ...
- 关于Android Assets读取文件为File对象
关于Android Assets读取文件为File对象的问题,在Assets里面放置文件,在使用的时候,一般是使用AssetManger对象,open方法获取InputStream 然后进行其他操作. ...
- python2 ----函数字典的使用
问题背景: 最近在用python2为sublime2写一个插件,其中有一个命令功能,就是输入不同的命令调用不同的函数,但是python不支持switch,只用ifelse的话感觉特别的low而且明显不 ...
- Python学习(五) Python数据类型:列表(重要)
列表: list是一组有序项目的数据结构. 列表是可变类型的数据,列表用[]进行表示,包含了多个以","分隔的项目. list=[] type(list) //<type ' ...