说明:

    学习python也有些日子,但从未真正用过,己经在心里谴责了N次了,终于下决定将自己学习的过程记录下来,虽然我这个人没有什么优点,但一坚持万一变成优点了呢!


一、实现一个函数isDuplicate(s),接受一个字符串,判断这个符串是否含有重复的字符,如果有的话函数返回True,没有的话返回False

1、思路:

    a、将输入的字符串转换成列表,字符串切片与列表比较,用list.count()>1则表示有重复字符,返回ture,并将原来的字符串及重复的字符输出

    b、如果列表循环完所有元素,扔没有找到重复的元素,则返回False 并输出源字符串

2、脚本内容:

#!/usr/bin/python
#! -*- coding:utf-8 -*-
import string
inputString=raw_input("请输入你要判断的字符串:")
punctuation=string.punctuation 
#sting.punctuation里面包含了32个英文标点符号
identify=' '*32
table=string.maketrans(punctuation,identify)
#makerans接受两个等长的参数,形成一个对应表
new_string=inputString.translate(table).replace(' ','')
#先用对应表和translate函数将字符串里面的标点符号用空格代替,然后去掉空格
def isDuplicate(new_string):
        l_str1=list(new_string)
        l_len=len(l_str1)
        l_str2=[]
        for i in xrange(0,(l_len-1)):
                sum=int(l_str1.count(new_string[i]))
                
                if sum > 1 :
                        l_str2.extend(new_string[i])                        
        if l_str2:
            print 'source string :%s' %new_string
            print "True"
            isDuplicate_list=set(l_str2)
            isDuplicate_str= [j for j in isDuplicate_list]
            print '-'.join(isDuplicate_str)
        else:
            print "False"
            print 'source string :%s' %new_string                
isDuplicate(new_string)

3、用到的知识:

    a、脚本中引用中文编码,需要指定字符编码

    b、字符串处理模块中的函数之--string.punctuation,在这里定义了32位英文标点符号

string.punctuation 
In [3]: help(string.punctuation)
no Python documentation found for '!"#$%&\'()*+,-./:;<=>?@[\\]^_`{|}~'

    c、字符串处理模块中的函数之--string.maketrans,形成两个等长字符串

string.maketrans
In [4]: help(string.maketrans)
Help on built-in function maketrans in module strop:

maketrans(...)
    maketrans(frm, to) -> string
    
    Return a translation table (a string of 256 bytes long)
    suitable for use in string.translate.  The strings frm and to
    must be of the same length.

    d、将字符串转换成列表--list(string)、列表长度len(list)、涉及到列表的开始位置(从0开始)

    f、xrange  函数说明:用法与range完全相同,所不同的是生成的不是一个数组,而是一个生成器。

       g、字符串切片,列表元素统计

       h、字符串追加到列表

       i、for 语句与if 语句的使用,需要说明的是在for语句中也可以使用else子句

       j、set用法,列表解析,列表合并为字符串

       k、函数的简单调用

二、实现一个函数isPalindrome(s),接受一个字符串参数,判断字符串是否是回文

1、思路:

        a、将要输入的字符反转

        b、使用深copy引用源串

        c、判断列表是否相同

2、脚本内容

#!/usr/bin/python
#! -*- coding:utf-8 -*-
  
import string
import copy
inputString=raw_input("请输入你要判断的字符串:")
punctuation=string.punctuation #sting.punctuation里面包含了32个英文标点符号
identify=' '*32
table=string.maketrans(punctuation,identify)#makerans接受两个等长的参数,形成一个对应表
new_list=inputString.translate(table).replace(' ','')#先用对应表和translate函数将字符串
#里面的标点符号用空格代替,然后去掉空格
  
inputString=list(new_string)#转换成列表,为的是使用反转函数
temp=copy.deepcopy(inputString)#深拷贝,如果只是用简单的等于号的话,
#那样只是引用而已,inputstring改变了,temp也会改变的,所以要深拷贝
inputString.reverse()#将列表反转
print inputString#打印出列表,为的是输出结果的时候,能观察上面的操作结果如何
print temp
if temp==inputString:#判断是否相等
    print "是回文"
else:
    print "不是回文"

3、用到的知识:

    a、将字符转换为列表

    b、深copy 

    c、使用列表的反转函数 

    d、打印两个列表

    f、if判断列表是否相同

    g、输出结果

注:最近发现一个不错的python在线编辑器,http://pythontutor.com/visualize.html#mode=edit ,用着很不错,类似于单步解析,对我这样菜鸟太有用了。