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实现抓取页面上链接的简单爬虫分享
Jan 21 Python
Python使用自带的ConfigParser模块读写ini配置文件
Jun 26 Python
python实现报表自动化详解
Nov 16 Python
Python实现图片尺寸缩放脚本
Mar 10 Python
Python实现E-Mail收集插件实例教程
Feb 06 Python
Python批量生成幻影坦克图片实例代码
Jun 04 Python
python安装virtualenv虚拟环境步骤图文详解
Sep 18 Python
使用python脚本自动创建pip.ini配置文件代码实例
Sep 20 Python
Python numpy.zero() 初始化矩阵实例
Nov 27 Python
基于python plotly交互式图表大全
Dec 07 Python
django2.2 和 PyMySQL版本兼容问题
Feb 17 Python
Python游戏开发实例之graphics实现AI五子棋
Nov 01 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编译configure时常见错误的总结
2017/08/17 PHP
fromCharCode和charCodeAt 方法
2006/12/27 Javascript
JQuery优缺点分析说明
2010/06/09 Javascript
node.js中的fs.ftruncate方法使用说明
2014/12/15 Javascript
javascript arguments使用示例
2014/12/16 Javascript
Eclipse配置Javascript开发环境图文教程
2015/01/29 Javascript
ECMAScript6块级作用域及新变量声明(let)
2015/06/12 Javascript
浅谈JavaScript中的作用域和闭包问题
2015/07/07 Javascript
JS实现从网页顶部掉下弹出层效果的方法
2015/08/06 Javascript
javascript入门之数组[新手必看]
2016/11/21 Javascript
Angualrjs 表单验证的两种方式(失去焦点验证和点击提交验证)
2017/05/09 Javascript
详解react-router如何实现按需加载
2017/06/15 Javascript
Vue Transition实现类原生组件跳转过渡动画的示例
2017/08/19 Javascript
基于jQuery Ajax实现下拉框无刷新联动
2017/12/06 jQuery
MVVM 双向绑定的实现代码
2018/06/21 Javascript
Vue.js 中的 v-model 指令及绑定表单元素的方法
2018/12/03 Javascript
js实现移动端轮播图
2020/12/21 Javascript
小程序实现人脸识别功能(百度ai)
2018/12/23 Javascript
Vue利用Blob下载原生二进制数组文件
2019/09/25 Javascript
[53:20]2018DOTA2亚洲邀请赛 4.1 小组赛 A组加赛 VG vs OG
2018/04/03 DOTA
Python中几种操作字符串的方法的介绍
2015/04/09 Python
python实现机器学习之多元线性回归
2018/09/06 Python
python datetime中strptime用法详解
2019/08/29 Python
python绘制雪景图
2019/12/16 Python
高级3D打印市场:Gambody
2019/12/26 全球购物
荣耀商城:HIHONOR
2020/11/03 全球购物
Ibatis如何调用存储过程
2015/05/15 面试题
Java多态性的定义以及类型
2014/09/16 面试题
省级优秀班集体申报材料
2014/05/25 职场文书
擅自离岗检讨书
2014/09/12 职场文书
党员对照检查材料整改措施思想汇报
2014/09/26 职场文书
介绍信应该怎么开?
2019/04/03 职场文书
JS监听Esc 键触发事键
2021/04/14 Javascript
MySQL完整性约束的定义与实例教程
2021/05/30 MySQL
MySQL学习必备条件查询数据
2022/03/25 MySQL
Vue 打包后相对路径的引用问题
2022/06/05 Vue.js