说明:
学习python也有些日子,但从未真正用过,己经在心里谴责了N次了,终于下决定将自己学习的过程记录下来,虽然我这个人没有什么优点,但一坚持万一变成优点了呢!
一、实现一个函数isDuplicate(s),接受一个字符串,判断这个符串是否含有重复的字符,如果有的话函数返回True,没有的话返回False
1、思路:
a、将输入的字符串转换成列表,字符串切片与列表比较,用list.count()>1则表示有重复字符,返回ture,并将原来的字符串及重复的字符输出
b、如果列表循环完所有元素,扔没有找到重复的元素,则返回False 并输出源字符串
2、脚本内容:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
#!/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位英文标点符号
1
2
3
|
string.punctuation
In [
3
]:
help
(string.punctuation)
no Python documentation found
for
'!"#$%&\'()*+,-./:;<=>?@[\\]^_`{|}~'
|
c、字符串处理模块中的函数之--string.maketrans,形成两个等长字符串
1
2
3
4
5
6
7
8
9
10
|
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、脚本内容
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
#!/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 ,用着很不错,类似于单步解析,对我这样菜鸟太有用了。