Python实现比较两个列表(list)范围


Posted in Python onJune 12, 2015

有一道题: 比较两个列表范围,如果包含的话,返回TRUE,否则FALSE。 详细题目如下:

Create a function, this function receives two lists as parameters, each list indicates a scope of numbers, the function judges whether list2 is included in list1.

 Function signature:
    differ_scope(list1, list2)

 Parameters:
    list1, list2    - list1 and list2 are constructed with strings,
                      each string indicates a number or a scope of
                      numbers. The number or scope are randomly, can
                      be overlapped. All numbers are positive.

                        E.g.
                            ['23', '44-67', '12', '3', '20-90']
 Return Values:
    True            - if all scopes and numbers indicated by list2 are included in list1.
    False           - if any scope or number in list2 is out of the range in list1.
 Examples:
    case1    - list1 = ['23', '44-67', '12', '3', '20-90']
               list2 = ['22-34', '33', 45', '60-61']
               differ_scope(list1, list2) == True
    case2    - list1 = ['23', '44-67', '12', '3', '20-90']
               list2 = ['22-34', '33', 45', '60-61', '100']
               differ_scope(list1, list2) == False

贴上自己写的代码如下:(备注: python 2.7.6)

def differ_scope(list1, list2): 
  print "list1:" + str(list1) 
  print "list2:" + str(list2) 
  #设置临时存放列表 
  list1_not_ = [] #用于存放列表1正常的数字值,当然要用int()来转换 
  list1_yes_ = [] #用于存放列表1中范围值如 44-67 
  list1_final = [] #用于存放列表1中最终范围值 如:[1,2,3,4,5,6,7,8,9,10] 
  temp1    = [] 
   
  list2_not_ = []  #用于存放列表2正常的数字值,当然要用int()来转换 
  list2_yes_ = []  #用于存放列表2中范围值如 44-67 
  list2_final= []  #用于存放列表2中最终范围值 如:[1,2,3,4,5,6,7,8,9,10] 
  temp2   = [] 
 
  temp    = []  #用于存放列表1,与列表2比较后的列表,从而判断结果为True还是False. 
   
  #对列表1进行处理 
  for i in range(len(list1)): #用FOR循环对列表1进行遍历 
    tag = 0 
    if list1[i].find('-')>0:#对含范围的数字进行处理,放到list_yes_列表中  
      strlist = list1[i].split('-') 
    list1_yes_ = range(int(strlist[0]),int(strlist[1])+1)#让其生成一个范围列表 
    for each in list1_yes_:     #FOR循环遍历所有符合条件的. 
        [temp1.append(each)] 
    else:           #对列表1中正常的数字进行处理,放到list_not_列表中 
      list1_not_.append(int(list1[i]))#对列表1中进行处理,放到list_yes_    
  [temp1.append(i) for i in list1_not_ if not i in temp1]#去除重复项 
  list1_final = sorted(temp1) #比较后,排序,并放到list1_final列表中 
  print "list1_final value is:" + str(list1_final)#打印排序后最终list1_final列表 
 
   
  #对列表2进行处理 
  for i in range(len(list2)): 
    if list2[i].find('-')>0: 
      strlist = list2[i].split('-') 
    list2_yes_ = range(int(strlist[0]),int(strlist[1])+1) 
    for each in list2_yes_: 
        [temp2.append(each)] 
      print "Temp2:" + str(temp2) 
    else: 
      list2_not_.append(int(list2[i])) 
  [temp2.append(i) for i in list2_not_ if not i in temp2] 
  list2_final = sorted(temp2) 
  print "list2_final value is:" + str(list2_final) 
 
  #对两个列表进行比较,得出最终比较结果. 
  [temp.append(i) for i in list2_final if not i in list1_final]#比较两个列表差值. 
  print "In list2 but not in list1:%s" % (temp)#打印出列表1与列表2的差值 
  if len(temp)>=1 : 
    print "The result is: False" 
  else: 
    print "The result is: True" 
 
if __name__ == '__main__': 
  list1 = ['23', '44-67', '12', '3','90-100'] 
  list2 = ['22-34', '33', '45'] 
  differ_scope(list1,list2)

总结:
1. 这道题关键是想法,如果整成坐标的方式来比较,会很麻烦。
2. 列表转成范围后,如果消除重复项,同样是里面的关键所在。
3. 其次是对列表遍历的操作,同样挺重要。

Python 相关文章推荐
python采集博客中上传的QQ截图文件
Jul 18 Python
python简单分割文件的方法
Jul 30 Python
python+logging+yaml实现日志分割
Jul 22 Python
Python中利用LSTM模型进行时间序列预测分析的实现
Jul 26 Python
使用python绘制二维图形示例
Nov 22 Python
python异常处理和日志处理方式
Dec 24 Python
Python实现代码块儿折叠
Apr 15 Python
python 读取二进制 显示图片案例
Apr 24 Python
python能在浏览器能运行吗
Jun 17 Python
Python工程师必考的6个经典面试题
Jun 28 Python
Python+Dlib+Opencv实现人脸采集并表情判别功能的代码
Jul 01 Python
如何通过python实现IOU计算代码实例
Nov 02 Python
在Linux系统上安装Python的Scrapy框架的教程
Jun 11 #Python
Python语言实现机器学习的K-近邻算法
Jun 11 #Python
在Linux下使用Python的matplotlib绘制数据图的教程
Jun 11 #Python
python中的代码编码格式转换问题
Jun 10 #Python
python实现数独算法实例
Jun 09 #Python
python中的全局变量用法分析
Jun 09 #Python
python简单实现计算过期时间的方法
Jun 09 #Python
You might like
PHP浮点数精度问题汇总
2015/05/13 PHP
PHP版本常用的排序算法汇总
2015/12/20 PHP
JavaScript 私有成员分析
2009/01/13 Javascript
jQuery 学习第五课 Ajax 使用说明
2010/05/17 Javascript
两种方法实现文本框输入内容提示消失
2013/03/17 Javascript
JS操作CSS随机改变网页背景实现思路
2014/03/10 Javascript
jQuery实现信息提示框(带有圆角框与动画)效果
2015/08/07 Javascript
node.js抓取并分析网页内容有无特殊内容的js文件
2015/11/17 Javascript
nodejs实现bigpipe异步加载页面方案
2016/01/26 NodeJs
Json解析的方法小结
2016/06/22 Javascript
Bootstrap实现提示框和弹出框效果
2017/01/11 Javascript
详解在AngularJS的controller外部直接获取$scope
2017/06/02 Javascript
JS内部事件机制之单线程原理
2018/07/02 Javascript
echarts实现词云自定义形状的示例代码
2019/02/20 Javascript
vue store之状态管理模式的详细介绍
2019/06/13 Javascript
vue调用语音播放的方法
2019/09/27 Javascript
vue自定义指令实现仅支持输入数字和浮点型的示例
2019/10/30 Javascript
vue-cli3项目升级到vue-cli4 的方法总结
2020/03/19 Javascript
《javascript设计模式》学习笔记五:Javascript面向对象程序设计工厂模式实例分析
2020/04/08 Javascript
python实现支付宝转账接口
2019/05/07 Python
详解用Python实现自动化监控远程服务器
2019/05/18 Python
基于python读取.mat文件并取出信息
2019/12/16 Python
Django choices下拉列表绑定实例
2020/03/13 Python
Python importlib动态导入模块实现代码
2020/04/16 Python
使用PyQt5实现图片查看器的示例代码
2020/04/21 Python
基于Python实现视频的人脸融合功能
2020/06/12 Python
html5音频_动力节点Java学院整理
2018/08/22 HTML / CSS
英格兰橄榄球商店:England Rugby Store
2016/12/17 全球购物
英国在线房屋中介网站:Yopa
2018/01/09 全球购物
MAC Cosmetics官方网站:魅可专业艺术彩妆
2019/04/10 全球购物
高一历史教学反思
2014/01/13 职场文书
土建专业大学生自荐信范文
2014/04/09 职场文书
幼儿园大班教师随笔
2015/08/14 职场文书
2016党员学习《反对自由主义》心得体会
2016/01/22 职场文书
2016年感恩母亲节活动总结
2016/04/01 职场文书
设置IIS Express并发数
2022/07/07 Servers