问题 A: 看电视
时间限制: 1 Sec 内存限制: 32 MB
题目描述
暑假到了,小明终于可以开心的看电视了。但是小明喜欢的节目太多了,他希望尽量多的看到完整的节目。
现在他把他喜欢的电视节目的转播时间表给你,你能帮他合理安排吗?
输入
输入包含多组测试数据。每组输入的第一行是一个整数n(n<=100),表示小明喜欢的节目的总数。
接下来n行,每行输入两个整数si和ei(1<=i<=n),表示第i个节目的开始和结束时间,为了简化问题,每个时间都用一个正整数表示。
当n=0时,输入结束。
输出
对于每组输入,输出能完整看到的电视节目的个数。
样例输入
12
1 3
3 4
0 7
3 8
15 19
15 20
10 15
8 18
6 12
5 10
4 14
2 9
0
样例输出
5
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn = 110;
struct Inteval{
int x, y; //x表示节目开始时间, y表示节目结束时间
}tv[maxn];
/**
按左端点从大到小排序,若左端点相同,按右端点从小到大排序
*/
bool cmp(Inteval a, Inteval b){
if(a.x != b.x)
return a.x > b.x;
else
return a.y < b.y;
}
int main(){
int n;
while(~scanf("%d", &n), n != 0){
for(int i = 0; i < n; i++){
scanf("%d%d", &tv[i].x, &tv[i].y);
}
sort(tv, tv + n, cmp);
// ans记录不相交的个数,lastX记录上一个区间的左端点
int ans = 1, lastX = tv[0].x;
for(int i = 1; i < n; i++){
if(tv[i].y <= lastX){
lastX = tv[i].x;
ans++;
}
}
printf("%d\n", ans);
}
return 0;
}
Python的闭包
什么是闭包?
通常将闭包理解为由一个内函数和一个外函数嵌套形成,其中,内函数里运用了外函数的临时变量,并且外函数的返回值是内函数的引用。这样就构成了一个闭包。
def lines(k, b):
def create(x):
print(k * x + b)
return create
line = lines(1, 2)
line(0)
可以用nonlocal 关键字声明 一个变量, 表示这个变量不是局部变量空间的变量,需要向上一层变量空间找这个变量
x = 300
def test1():
x = 200
def test2():
nonlocal x # nonlocal可以修改外层函数的变量
print("----x=%d" % x)
x = 100
print("---x=%d" % x)
return test2
t1 = test1()
t1()
-------------------------------------------
打印结果:
----x=200
---x=100
闭包的作用主要在装饰器。装饰器明天再说溜了溜了。