[百度之星] 2005年百度之星程序大赛初赛题目(重叠区间大小)
2014-03-21 11:19
267 查看
[align=left]第二题(共四题100分):重叠区间大小(20分)[/align] 题目描述: 请编写程序,找出下面“输入数据及格式”中所描述的输入数据文件中最大重叠区间的大 小。 对一个正整数n,如果n在数据文件中某行的两个正整数(假设为A和B)之间,即A< =n <=B或A>=n>=B,则n属于该行;如果n同时属于行i和j,则i和j有重叠区间;重叠区间的大 小是同时属于行i和j的整数个数。 例如, 行(10 20)和(12 25)的重叠区间为[12 20],其大小为9;行(2010)和( 12 18)的重叠区间为[10 12],其大小为3;行(20 10)和(20 30)的重叠区间大小为1。 输入数据: 程序读入已被命名为input.txt的输入数据文本文件,该文件的行数在1到1,000,000之间, 每行有用一个空格分隔的2个正整数,这2个正整数的大小次序随机,每个数都在1和2^32- 1之间。(为便于调试,您可下载测试input.txt文件,实际运行时我们会使用不同内容的 输入文件。) 输出数据: 在标准输出上打印出输入数据文件中最大重叠区间的大小,如果所有行都没有重叠区间, 则输出0。 评分标准: 程序输出结果必须正确,内存使用必须不超过256MB,程序的执行时间越快越好。 [align=left]python 2.7版:[/align] #!/user/bin/env/ python # -*- coding: utf-8 -*- f = open('input.txt') sumlist =[] maxlength = 0 for line in f: temptuple = line.split(' ') temptuple = (int(temptuple[0]),int(temptuple[1])) sorted(temptuple) # sumlist.append(temptuple) for i in range(0,len(sumlist)-1): #print(sumlist[i]) if(sumlist[i][1] == temptuple[0]): if(maxlength < 1): maxlength = 1 elif(sumlist[i][1] > temptuple[0]): if(temptuple[0] > sumlist[i][0]): t1 = temptuple[0] else: t1 = sumlist[i][0] if(temptuple[1] > sumlist[i][1]): t2 = sumlist[i][1] else: t2 = temptuple[1] if(maxlength < (t2 -t1)): maxlength = t2 - t1 #print(sumlist[i]) #print(temptuple) print(maxlength) #print(sumlist) |
相关文章推荐
- 2005年百度之星程序设计大赛试题初赛题目二的解答(重叠区间大小)
- 2005年百度之星程序大赛初赛题目(连续正整数)
- 2011年百度之星程序大赛初赛第一场题目(图标排列)
- 2005年百度之星初赛题目第一题(连续正整数)
- 百度之星 2005年 初赛题目一 java 版本
- 区间重合判断、百度之星题解之重叠区间大小
- 百度之星2005年初赛题目
- star.baidu.com程序设计大赛初赛、复赛题目
- [原创]百度之星题解之重叠区间大小
- 百度之星程序设计大赛-初赛题2-重叠区间大小
- 2017"百度之星"程序设计大赛 - 初赛(B)1006.小小粉丝度度熊【预处理区间+二分】
- 2005年Goole编程大赛初赛题目二(750分)
- 面试题精选(69):求最大重叠区间大小
- 2017"百度之星"程序设计大赛 - 初赛(A)今夕何夕
- 2017"百度之星"程序设计大赛 - 初赛(A)
- HDU 6108 小C的倍数问题 【数学】 (2017"百度之星"程序设计大赛 - 初赛(A))
- HDU 6109 数据分割 【并查集+set】 (2017"百度之星"程序设计大赛 - 初赛(A))
- [HDU6118][2017"百度之星"程序设计大赛 - 初赛(B)]度度熊的交易计划
- 2017"百度之星"程序设计大赛 - 初赛(B)小小粉丝度度熊
- 2017"百度之星"程序设计大赛 - 初赛(A)1001 小C的倍数问题(数学问题)