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的Django框架中获取单个对象数据的简单方法
Jul 17 Python
python 读写、创建 文件的方法(必看)
Sep 12 Python
Python双精度浮点数运算并分行显示操作示例
Jul 21 Python
python实现简单遗传算法
Mar 19 Python
Pandas:DataFrame对象的基础操作方法
Jun 07 Python
解决Pycharm运行时找不到文件的问题
Oct 29 Python
解决在pycharm中显示额外的 figure 窗口问题
Jan 15 Python
django实现web接口 python3模拟Post请求方式
Nov 19 Python
python add_argument()用法解析
Jan 29 Python
浅谈Pycharm最有必要改的几个默认设置项
Feb 14 Python
基于spring boot 日志(logback)报错的解决方式
Feb 20 Python
使用python批量修改XML文件中图像的depth值
Jul 22 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调用C#开发的dll类库方法
2014/07/28 PHP
PHP设计模式之命令模式示例详解
2020/12/20 PHP
js 自动播放的实例代码
2013/11/19 Javascript
JavaScript学习笔记之JS对象
2015/01/22 Javascript
JavaScript中的anchor()方法使用详解
2015/06/08 Javascript
jquery实现带渐变淡入淡出并向右依次展开的多级菜单效果实例
2015/08/22 Javascript
使用JQuery实现智能表单验证功能
2016/03/08 Javascript
jQuery Easyui Tabs扩展根据自定义属性打开页签
2016/08/15 Javascript
jQuery双向列表选择器select版
2016/11/01 Javascript
Vue2.5通过json文件读取数据的方法
2018/02/27 Javascript
vue中使用echarts制作圆环图的实例代码
2018/07/27 Javascript
JavaScript常用进制转换及位运算实例解析
2020/10/14 Javascript
[31:00]2014 DOTA2华西杯精英邀请赛5 24 NewBee VS iG
2014/05/25 DOTA
python使用心得之获得github代码库列表
2014/06/25 Python
使用Python的Django框架实现事务交易管理的教程
2015/04/20 Python
关于python的list相关知识(推荐)
2017/08/30 Python
python在文本开头插入一行的实例
2018/05/02 Python
python如何实现一个刷网页小程序
2018/11/27 Python
pyqt5 实现在别的窗口弹出进度条
2019/06/18 Python
pyqt5实现绘制ui,列表窗口,滚动窗口显示图片的方法
2019/06/20 Python
使用pycharm在本地开发并实时同步到服务器
2019/08/02 Python
python Plotly绘图工具的简单使用
2020/03/03 Python
Clarisonic美国官网:科莱丽声波洁面仪
2017/10/12 全球购物
澳洲的UGG雪地靴超级市场:Uggs.com.au
2020/04/06 全球购物
中专自我鉴定范文
2013/10/16 职场文书
护士专业推荐信
2013/11/02 职场文书
校园新闻广播稿
2014/01/10 职场文书
写给老婆的检讨书
2014/02/21 职场文书
关爱留守儿童倡议书
2014/04/15 职场文书
2014年民政局关于保密工作整改措施
2014/09/19 职场文书
离婚协议书包括哪些内容
2014/10/16 职场文书
2014年中班下学期工作总结
2014/12/11 职场文书
五年级下册复习计划
2015/01/19 职场文书
2015年国际护士节演讲稿
2015/03/18 职场文书
数据库之SQL技巧整理案例
2021/07/07 SQL Server
Python自动操作神器PyAutoGUI的使用教程
2022/06/16 Python