Python针对给定字符串求解所有子序列是否为回文序列的方法


Posted in Python onApril 21, 2018

本文实例讲述了Python针对给定字符串求解所有子序列是否为回文序列的方法。分享给大家供大家参考,具体如下:

问题:

给定一个字符串,得到所有的子序列,判断是否为回文序列

思路:

对字符串遍历切片即可

下面是具体实现:

#!usr/bin/env python
# -*- coding:utf-8 -*-
'''''
__AUthor__:沂水寒城
功能:对指定字符串寻找所有回文子序列
'''
def is_huiwen(one_str_list):
  '''''
  输入一个字符串列表,判断是否为回文序列
  '''
  if len(one_str_list)==1:
    return True
  else:
    half=len(one_str_list)/2
    if len(one_str_list)%2==0:
      first_list=one_str_list[:half]
      second_list=one_str_list[half:]
    else:
      first_list=one_str_list[:half]
      second_list=one_str_list[half+1:]
    if first_list==second_list[::-1]:
      return True
    else:
      return False
def get_list_all_sub_list(num_list):
  '''
  输入一个列表,返回该列表所有的子列表,这里定义的空列表不属于子列表,故:子列表最小长度为1
  '''
  if len(num_list)==1:
    return [num_list]
  sub_list=get_list_all_sub_list(num_list[:-1])
  extra=num_list[-1:]
  temp_list=[]
  for one in sub_list:
    temp_list.append(one+extra)
  return sub_list+temp_list
def slice_func(one_str):
  '''''
  '''
  result_list=[]
  for i in range(1,len(one_str)):
    result_list.append(one_str[:i])
    result_list.append(one_str[i:])
  result_list+=list(one_str)
  result_list.append(one_str)
  return list(set(result_list))
def main_func2():
  '''''
  主调用函数
  '''
  str_list=['abdc','abba']
  for one_str in str_list:
    result_list=slice_func(one_str)
    print '-----------------------------------------------'
    for one in result_list:
      if is_huiwen(list(one)):
        print one+'是回文序列'
def main_func1():
  '''''
  主调用函数
  '''
  str_list=['abdc','abba']
  for one_str in str_list:
    one_str_list=list(one_str)
    one_all_sub_list=get_list_all_sub_list(one_str_list)
    print '------------------------------------------------'
    print one_all_sub_list
    for one in one_all_sub_list:
      if is_huiwen(one):
        print ''.join(one)+'是回文序列'
if __name__ == '__main__':
  print "三水点靠木测试结果:"
  main_func2()

结果如下:

Python针对给定字符串求解所有子序列是否为回文序列的方法

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
自己编程中遇到的Python错误和解决方法汇总整理
Jun 03 Python
Python的Flask站点中集成xhEditor文本编辑器的教程
Jun 13 Python
Python字符串格式化%s%d%f详解
Feb 02 Python
Python测试人员需要掌握的知识
Feb 08 Python
python基础教程项目四之新闻聚合
Apr 02 Python
Python使用pyautogui模块实现自动化鼠标和键盘操作示例
Sep 04 Python
如何在django里上传csv文件并进行入库处理的方法
Jan 02 Python
Python中判断子串存在的性能比较及分析总结
Jun 23 Python
python 给图像添加透明度(alpha通道)
Apr 09 Python
Tensorflow中k.gradients()和tf.stop_gradient()用法说明
Jun 10 Python
Python爬虫headers处理及网络超时问题解决方案
Jun 19 Python
python怎么自定义捕获错误
Jun 29 Python
Django项目实战之用户头像上传与访问的示例
Apr 21 #Python
基于Python 装饰器装饰类中的方法实例
Apr 21 #Python
使用python装饰器计算函数运行时间的实例
Apr 21 #Python
Python实现针对给定字符串寻找最长非重复子串的方法
Apr 21 #Python
Python 实现一行输入多个值的方法
Apr 21 #Python
Python实现接受任意个数参数的函数方法
Apr 21 #Python
深入分析python数据挖掘 Json结构分析
Apr 21 #Python
You might like
PHP+Mysql+jQuery实现发布微博程序 jQuery篇
2011/10/08 PHP
php和mysql中uft-8中文编码乱码的几种解决办法
2012/04/19 PHP
解决CodeIgniter伪静态失效
2014/06/09 PHP
详解WordPress中的头像缓存和代理中的缓存更新方法
2016/03/01 PHP
Expandable "Detail" Table Rows
2007/08/29 Javascript
Javascript操作select方法大全[新增、修改、删除、选中、清空、判断存在等]
2008/09/26 Javascript
Javascript 函数对象的多重身份
2009/06/28 Javascript
JQuery 操作select标签实现代码
2010/05/14 Javascript
iframe 父窗口和子窗口相互的调用方法集锦
2010/12/15 Javascript
IE6中使用position导致页面变形的解决方案(js代码)
2011/01/09 Javascript
js中点击空白区域时文本框与隐藏层的显示与影藏问题
2013/08/26 Javascript
jquery实现文本框数量加减功能的例子分享
2014/05/10 Javascript
jQuery中:contains选择器用法实例
2014/12/30 Javascript
Bootstrap超大屏幕的实现代码
2017/03/22 Javascript
使用Xcache缓存器加速PHP网站的配置方法
2017/04/22 Javascript
javascript基本常用排序算法解析
2017/09/27 Javascript
JavaScript实现随机数生成器(去重)
2017/10/13 Javascript
Angularjs之如何在跨域请求中传输Cookie的方法
2018/06/01 Javascript
vue计算属性computed、事件、监听器watch的使用讲解
2019/01/21 Javascript
Vue的自定义组件不能使用click方法的解决
2020/07/28 Javascript
[01:39](回顾)各路豪强针锋相对,几经鏖战四强产生
2014/07/01 DOTA
Python实现数值积分方式
2019/11/20 Python
pytorch标签转onehot形式实例
2020/01/02 Python
python3.6中anaconda安装sklearn踩坑实录
2020/07/28 Python
什么是数据库锁?Oracle中都有哪些类型的锁?
2015/08/21 面试题
营销与策划专业毕业生求职信
2013/11/01 职场文书
服装厂厂长职责
2013/12/16 职场文书
科技开发中心办公室主任岗位责任制
2014/02/10 职场文书
大学自主招生推荐信
2014/05/10 职场文书
入职担保书怎么写
2014/05/12 职场文书
动漫设计与制作专业推荐信
2014/07/07 职场文书
党员“四风”方面存在问题及整改措施
2014/09/24 职场文书
个人先进事迹材料范文
2014/12/29 职场文书
管理失职检讨书
2015/05/05 职场文书
2019年销售人员的职业生涯规划书
2019/03/25 职场文书
CentOS7安装GlusterFS集群以及相关配置
2022/04/12 Servers