python練習之列表和字典
1.字串最後一個單詞的長度
題目描述:計算字串最後一個單詞的長度,單詞以空格隔開。
輸入描述: 一行字串,非空,長度小於5000。
輸出描述: 整數N,最後一個單詞的長度。
示例1:
輸入:hello world
輸出:5
#!/usr/bin/env python
#coding:utf-8
"""
計算字串最後一個單詞的長度,單詞以空格隔開
#用try except 處理程式異常!
"""
while 1:
try:
l = raw_input()
if len(l) == 0:
print "請正確輸入字串!"
break
if len(l)>5000:
l=l[:5000]
wordList=l.split()
print len(wordList[-1])
except:
break
2. 計算字元個數
題目描述: 寫出一個程式,接受一個有字母和數字以及空格組成的字串,和一個字元,然後輸出輸入字串中含有該字元的個數。不區分大小寫。
輸入描述: 輸入一個有字母和數字以及空格組成的字串,和一個字元。
輸出描述:輸出輸入字串中含有該字元的個數。
示例1:
輸入:ABCDEF A
輸出:1
#!/usr/bin/env python
#coding:utf-8
"""
寫出一個程式,接受一個有字母和數字以及空格組成的字串,
和一個字元,然後輸出輸入字串中含有該字元的個數,不區分大小寫。
"""
s = raw_input()
ch = raw_input()
num = 0
s = s.lower() if isinstance(s, str) else s #isinstance 判斷是否為字串
ch = ch.lower() if isinstance(ch, str) else ch
for i in s:
if ch == i:
num +=1
print num
3. 簡單密碼破解
題目描述:密碼是我們生活中非常重要的東東,我們的那麼一點不能說的祕密就全靠它了。哇哈哈. 接下來淵子要在密碼之上再加一套密碼,雖然簡單但也安全。
假設淵子原來一個BBS上的密碼為zvbo9441987,為了方便記憶,他通過一種演算法把這個密碼變換成YUANzhi1987,這個密碼是他的名字和出生年份,怎麼忘都忘不了,而且可以明目張膽地放在顯眼的地方而不被別人知道真正的密碼。
他是這麼變換的,大家都知道手機上的字母: 1–1, abc–2, def–3, ghi–4, jkl–5, mno–6, pqrs–7, tuv–8 wxyz–9, 0–0,就這麼簡單,淵子把密碼中出現的小寫字母都變成對應的數字,數字和其他的符號都不做變換,
宣告:密碼中沒有空格,而密碼中出現的大寫字母則變成小寫之後往後移一位,如:X,先變成小寫,再往後移一位,不就是y了嘛,簡單吧。記住,z往後移是a哦。
輸入描述:輸入包括多個測試資料。輸入是一個明文,密碼長度不超過100個字元,輸入直到檔案結尾;
輸出描述:輸出淵子真正的密文
示例1:
輸入:YUANzhi1987
輸出:zvbo9441987
#!/usr/bin/env python
#coding:utf-8
shuzi = '0123456789'
zimu = 'zxcvbnmasdfghjklqwertyuiop'
zimu1 = 'ZXCVBNMASDFGHJKLQWERTYUIOP'
s = raw_input ("請輸入密碼:")
l = list(s)
for i in range (len(l)):
if l[i] in shuzi:
continue
elif l[i] in zimu:
n = (ord(l[i]) - 91) / 3
if n > 9:
n = '9'
else:
n = '4'
l[i] = n
elif l[i] in zimu1:
s1 = chr(ord(l[i]) + 33)
l[i] = s1
else:
print "輸入非法字元:"
print ''.join(l)
4. (2017-騰訊-線上程式設計題)
- 題目描述:
給定一個正整數,編寫程式計算有多少對質數的和等於輸入的這個正整數,並輸出結果。輸入值小於1000。
如,輸入為10, 程式應該輸出結果為2。(共有兩對質數的和為10,分別為(5,5),(3,7))
輸入描述:
輸入包括一個整數n,(3 ≤ n < 1000)輸出描述:
輸出對數示例1 :
輸入:
10
輸出:
2
#!/usr/bin/env python
#coding:utf-8
def panduanzhishu(x):
if x <= 1:
return False
else:
min = 2
while min < x:
if x % min == 0:
return False
min += 1
else:
return True
n=input("請輸入:")
l=[]
for i in range(3,n):
if panduanzhishu(i):
l.append(i)
count=0
for i in range(0,len(l)):
x=l.pop()
y=n-x
if x==y:
count+=1
elif l.count(y) > 0:
count+=1
print count