說明:
學習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
<code>#!/usr/bin/python</code>
<code>#! -*- coding:utf-8 -*-</code>
<code>import</code> <code>string</code>
<code>inputString</code><code>=</code><code>raw_input</code><code>(</code><code>"請輸入你要判斷的字元串:"</code><code>)</code>
<code>punctuation</code><code>=</code><code>string.punctuation </code>
<code>#sting.punctuation裡面包含了32個英文标點符号</code>
<code>identify</code><code>=</code><code>' '</code><code>*</code><code>32</code>
<code>table</code><code>=</code><code>string.maketrans(punctuation,identify)</code>
<code>#makerans接受兩個等長的參數,形成一個對應表</code>
<code>new_string</code><code>=</code><code>inputString.translate(table).replace(</code><code>' '</code><code>,'')</code>
<code>#先用對應表和translate函數将字元串裡面的标點符号用空格代替,然後去掉空格</code>
<code>def</code> <code>isDuplicate(new_string):</code>
<code> </code><code>l_str1</code><code>=</code><code>list</code><code>(new_string)</code>
<code> </code><code>l_len</code><code>=</code><code>len</code><code>(l_str1)</code>
<code> </code><code>l_str2</code><code>=</code><code>[]</code>
<code> </code><code>for</code> <code>i </code><code>in</code> <code>xrange</code><code>(</code><code>0</code><code>,(l_len</code><code>-</code><code>1</code><code>)):</code>
<code> </code><code>sum</code><code>=</code><code>int</code><code>(l_str1.count(new_string[i]))</code>
<code> </code>
<code> </code><code>if</code> <code>sum</code> <code>> </code><code>1</code> <code>:</code>
<code> </code><code>l_str2.extend(new_string[i]) </code>
<code> </code><code>if</code> <code>l_str2:</code>
<code> </code><code>print</code> <code>'source string :%s'</code> <code>%</code><code>new_string</code>
<code> </code><code>print</code> <code>"True"</code>
<code> </code><code>isDuplicate_list</code><code>=</code><code>set</code><code>(l_str2)</code>
<code> </code><code>isDuplicate_str</code><code>=</code> <code>[j </code><code>for</code> <code>j </code><code>in</code> <code>isDuplicate_list]</code>
<code> </code><code>print</code> <code>'-'</code><code>.join(isDuplicate_str)</code>
<code> </code><code>else</code><code>:</code>
<code> </code><code>print</code> <code>"False"</code>
<code> </code><code>print</code> <code>'source string :%s'</code> <code>%</code><code>new_string </code>
<code>isDuplicate(new_string)</code>
3、用到的知識:
a、腳本中引用中文編碼,需要指定字元編碼
b、字元串處理子產品中的函數之--string.punctuation,在這裡定義了32位英文标點符号
<code>string.punctuation </code>
<code>In [</code><code>3</code><code>]: </code><code>help</code><code>(string.punctuation)</code>
<code>no Python documentation found </code><code>for</code> <code>'!"#$%&\'()*+,-./:;<=>?@[\\]^_`{|}~'</code>
c、字元串處理子產品中的函數之--string.maketrans,形成兩個等長字元串
<code>string.maketrans</code>
<code>In [</code><code>4</code><code>]: </code><code>help</code><code>(string.maketrans)</code>
<code>Help</code> <code>on built</code><code>-</code><code>in</code> <code>function maketrans </code><code>in</code> <code>module strop:</code>
<code>maketrans(...)</code>
<code> </code><code>maketrans(frm, to) </code><code>-</code><code>> string</code>
<code> </code>
<code> </code><code>Return a translation table (a string of </code><code>256</code> <code>bytes </code><code>long</code><code>)</code>
<code> </code><code>suitable </code><code>for</code> <code>use </code><code>in</code> <code>string.translate. The strings frm </code><code>and</code> <code>to</code>
<code> </code><code>must be of the same length.</code>
d、将字元串轉換成清單--list(string)、清單長度len(list)、涉及到清單的開始位置(從0開始)
f、xrange 函數說明:用法與range完全相同,所不同的是生成的不是一個數組,而是一個生成器。
g、字元串切片,清單元素統計
h、字元串追加到清單
i、for 語句與if 語句的使用,需要說明的是在for語句中也可以使用else子句
j、set用法,清單解析,清單合并為字元串
k、函數的簡單調用
二、實作一個函數isPalindrome(s),接受一個字元串參數,判斷字元串是否是回文
a、将要輸入的字元反轉
b、使用深copy引用源串
c、判斷清單是否相同
2、腳本内容
<code> </code>
<code>import</code> <code>copy</code>
<code>punctuation</code><code>=</code><code>string.punctuation </code><code>#sting.punctuation裡面包含了32個英文标點符号</code>
<code>table</code><code>=</code><code>string.maketrans(punctuation,identify)</code><code>#makerans接受兩個等長的參數,形成一個對應表</code>
<code>new_list</code><code>=</code><code>inputString.translate(table).replace(</code><code>' '</code><code>,'')</code><code>#先用對應表和translate函數将字元串</code>
<code>#裡面的标點符号用空格代替,然後去掉空格</code>
<code>inputString</code><code>=</code><code>list</code><code>(new_string)</code><code>#轉換成清單,為的是使用反轉函數</code>
<code>temp</code><code>=</code><code>copy.deepcopy(inputString)</code><code>#深拷貝,如果隻是用簡單的等于号的話,</code>
<code>#那樣隻是引用而已,inputstring改變了,temp也會改變的,是以要深拷貝</code>
<code>inputString.reverse()</code><code>#将清單反轉</code>
<code>print</code> <code>inputString</code><code>#列印出清單,為的是輸出結果的時候,能觀察上面的操作結果如何</code>
<code>print</code> <code>temp</code>
<code>if</code> <code>temp</code><code>=</code><code>=</code><code>inputString:</code><code>#判斷是否相等</code>
<code> </code><code>print</code> <code>"是回文"</code>
<code>else</code><code>:</code>
<code> </code><code>print</code> <code>"不是回文"</code>
a、将字元轉換為清單
b、深copy
c、使用清單的反轉函數
d、列印兩個清單
f、if判斷清單是否相同
g、輸出結果
本文轉自 jinlinger 51CTO部落格,原文連結:http://blog.51cto.com/essun/1604507,如需轉載請自行聯系原作者