Python3經典100例(①)
例項1
- 題目:有四個數字:1、2、3、4,能組成多少個互不相同且無重複數字的三位數?各是多少?
- 分析:通過三層迴圈,將個、十、百位上的數分別迴圈一次,當其中任意兩位相同時,則跳過,當各位上的數都不同時,輸出
- 程式碼:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2018-10-3 11:10
# @Author : Manu
# @Site :
# @File : group.py
# @Software: PyCharm
count = 0
for i in range(1, 5):
for j in range(1, 5):
for k in range(1, 5):
if i != j and i != k and k != j:
print(i, j, k)
count += 1
print("組成的數共有:%d 個" % count)
- 結果:
例項2
- 題目:企業發放的獎金根據利潤提成。利潤(I)低於或等於10萬元時,獎金可提10%;利潤高於10萬元,低於20萬元時,低於10萬元的部分按10%提成,高於10萬元的部分,可提成7.5%;20萬到40萬之間時,高於20萬元的部分,可提成5%;40萬到60萬之間時高於40萬元的部分,可提成3%;60萬到100萬之間時,高於60萬元的部分,可提成1.5%,高於100萬元時,超過100萬元的部分按1%提成,從鍵盤輸入當月利潤I,求應發放獎金總數?
- 分析:進入死迴圈,然後輸入企業利潤,然後計算出每一階段利潤內所對應獎金並儲存在一個變數中,最後輸出儲存獎金的變數值即可;
- 程式碼:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2018-10-3 12:10
# @Author : Manu
# @Site :
# @File : bonus.py
# @Software: PyCharm
while True:
profit = int(input("Input the profit"))
print("利潤是 %d 萬元" % profit)
if profit <= 10:
bonus = profit * 0.1
elif profit > 10 and profit < 20:
bonus = 10 * 0.1 + (profit - 10) * 0.075;
elif profit >= 20 and profit < 40:
bonus = 10 * 0.1 + (20 - 10) * 0.075 + 0.05 * (profit - 20)
elif profit >= 40 and profit < 60:
bonus = 10 * 0.1 + (20 - 10) * 0.075 + 0.05 * (40 - 20) + 0.03 * (profit - 40)
elif profit >= 60 and profit < 100:
10 * 0.1 + (20 - 10) * 0.075 + 0.05 * (40 - 20) + 0.03 * (60 - 40) + (profit - 60) * 0.015
else:
bonus = 10 * 0.1 + (20 - 10) * 0.075 + 0.05 * (40 - 20) + 0.03 * (60 - 40) + (100 - 60) * 0.015 + (profit - 100) * 0.01
print("獎金是 %f 萬元" %bonus)
- 結果:
例項3
-
題目:一個整數,它加上100後是一個完全平方數,再加上168又是一個完全平方數,請問該數是多少?
-
分析:如果一個正整數 a 是某一個整數 b 的平方,那麼這個正整數 a 叫做完全平方數;
假設這個數為 x:
1、則:x + 100 = n ** 2, x + 100 + 168 = m ** 2;
2、計算等式:m ** 2 - n ** 2 = (m + n)(m - n) = 168;
3、設定: m + n = i,m - n = j,i * j =168,i 和 j 至少一個是偶數;
4、可得: m = (i + j) / 2, n = (i - j) / 2,i 和 j 要麼都是偶數,要麼都是奇數;
5、從 3 和 4 推導可知道,i 與 j 均是大於等於 2 的偶數;
6、由於 i * j = 168, j>=2,則 1 < i < 168 / 2 + 1; -
程式碼:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2018-10-3 12:10
# @Author : Manu
# @Site :
# @File : compSquNum.py
# @Software: PyCharm
res = 168 // 2
for i in range(1, res + 1):
if 168 % i == 0:
j = 168 / i;
if i > j and (i + j) % 2 == 0 and (i - j) % 2 == 0 :
m = (i + j) / 2
n = (i - j) / 2
x = m * m - 268
print('這個數可能是: ', x)
- 結果:
例項4
- 題目:輸入某年某月某日,判斷這一天是這一年的第幾天?
- 分析:分別將平年和閏年每個月的天數存入兩個列表中,然後輸入年月日,判斷平年還是閏年,然後進行計算這是這一年中的第幾天;
- 程式碼:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2018-10-3 14:10
# @Author : Manu
# @Site :
# @File : day.py
# @Software: PyCharm
list1 = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
list2 = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
while True:
year = int(input('輸入年份'))
month = int(input('輸入月份'))
day = int(input('輸入日期'))
sum = 0
if year % 400 == 0 or (year % 4 == 0 and year % 100 != 0):
for i in range(month - 1):
sum += list2[i]
sum += day
else:
for i in range(month - 1):
sum += list1[i]
sum += day
print('這是第 %d 天' %sum)
- 結果:
例項5
- 題目:輸入三個整數x,y,z,請把這三個數由小到大輸出。
- 分析:進入死迴圈,然後分3次輸入,每次輸入後將其追加到列表中,然後對列表進行排序,最後輸出排序好的列表;
- 程式碼:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2018-10-3 15:10
# @Author : Manu
# @Site :
# @File : sortNum.py
# @Software: PyCharm
while True:
print('Input x, y, z:')
arr = []
for i in range(3):
tmp = int(input())
arr.append(tmp)
arr.sort()
print('三個數從小到大排序: ', arr)
- 結果:
相關文章
- SICP 經典
- 人工智慧研究:經典推理和非經典推理人工智慧
- Spring 經典教程Spring
- AT 經典90題
- 巨經典論文!推薦系統經典模型Wide & Deep模型IDE
- jvm經典文章整理JVM
- corn表示式 經典
- 經典面試題面試題
- JavaScript經典案例(二)JavaScript
- NLP的經典書
- 文章經典總結
- js經典題目JS
- 經典的反轉
- MySQL經典案例分析MySql
- YFII經典語錄
- 經典 backbone 總結
- csharp入門經典CSharp
- “四書五經”經典語句
- javascript經典面試題JavaScript面試題
- java經典面試題Java面試題
- JavaScript經典筆試題JavaScript筆試
- 李嘉誠經典名言
- 經典的行佈局
- Maven經典使用指南Maven
- 勵志格言經典短句
- 面試經典:Event Loop面試OOP
- Js 經典面試題JS面試題
- 經典揹包問題
- 《驚封》經典語錄
- 蘋果經典產品蘋果
- 前端經典面試題前端面試題
- Lisp經典演算法Lisp演算法
- LeetCode經典題-篇一LeetCode
- 連結串列經典示例
- Java基礎經典案例Java
- 經典語句(L篇)
- 人臉識別三大經典演算法(附經典論文列表)演算法
- 部分JS經典題目解析JS