天天看點

python初學之一

說明:

    學習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>&gt; </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>'!"#$%&amp;\'()*+,-./:;&lt;=&gt;?@[\\]^_`{|}~'</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>&gt; 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,如需轉載請自行聯系原作者