如果兩個整數各位數字的和是一樣的,則被稱為是「朋友數」,而那個公共的和就是它們的「朋友證號」。例如 123 和 51 就是朋友數,因為 1+2+3 = 5+1 = 6,而 6 就是它們的朋友證號。給定一些整數,要求你統計一下它們中有多少個不同的朋友證號。
輸入第一行給出正整數 n。隨後一行給出 n 個正整數,數字間以空格分隔。題目保證所有數字小於 10^4。
首先第一行輸出給定數字中不同的朋友證號的個數;隨後一行按遞增順序輸出這些朋友證號,數字間隔乙個空格,且行末不得有多餘空格。
8
123 899 51 998 27 33 36 12
4
3 6 9 26
此題也十分簡單;思路:所有的數看作字串,寫乙個函式,遍歷計算每個數字的和,存入集合中去重,最後排序。
n = int(input())
nums = input().split()
sumset = set()
def getsum(n):
s = 0
for char in n:
s += int(char)
return s
for n in nums:
sumset.add(getsum(n))
lst = list(sumset)
lst.sort()
lst = list(map(str, lst))
print(len(lst))
print(" ".join(lst))
2 兩數相加 python
題目 兩個非空鍊錶表示兩個非負整數,逆序儲存,將兩鍊錶表示的數相加,返回乙個新的逆序鍊錶 法 兩數加法,只是用鍊錶逆序表示,相當於頭節點是個位數字,後面依次是十位 百位數等 注意 1 考慮進製,尤其是最後一次的進製,當兩個鍊錶都遍歷完之後如果還有進製,再在尾部增加乙個節點 2 要記得每次移動指標,避...
Python練習2 隨機數產生
或者優惠券 使用 python 如何生成 200 個啟用碼 或者優惠券 這道題主要用來熟悉python的隨機函式,用到了random模組,大家可以參考python中的random模組 至於做題中遇到的坑,原始檔在命名的時候用了random,導致使用random模組的函式時一直執行錯誤,python中...
leetcode 2 兩數相加 python
給定兩個非空鍊錶來表示兩個非負整數。位數按照逆序方式儲存,它們的每個節點只儲存單個數字。將兩數相加返回乙個新的鍊錶。你可以假設除了數字 0 之外,這兩個數字都不會以零開頭。示例 輸入 2 4 3 5 6 4 輸出 7 0 8原因 342 465 8071 正常思路 definition for si...