Python 是一種面向對象、解釋型的腳本語言,同時也是一種功能強大而完善的通用型語言。相比其他編程語言(比如 Java),Python 代碼非常簡單,上手非常容易。
舉個例子,比如要完成某個功能,如果用 Java 需要 100 行代碼,但用 Python 可能只需要 20 行代碼,這是 Python 具有巨大吸引力的一大特點。
不僅如此,Python 還有其他的特點:
1、簡單易學
Python 是一種代表簡單注意思想的語言,閱讀一個良好的 Python 程序,即使是在 Python 語法要求非常嚴格的大環(huán)境下,給人的感覺也像是在讀英語段落一樣。
換句話說,Python 編程語言最大的優(yōu)點之一,是其具有偽代碼的特質,它可以讓我們在開發(fā) Python 程序時,專注于解決問題,而不是搞明白語言本身。
2、開源
Python 是 ?FLOSS(自由/開源源碼軟件)之一,簡單地理解就是,用戶使用 Python 進行開發(fā)和發(fā)布自己編寫的程序,不需要支付任何費用,也不用擔心版權問題,即使作為商業(yè)用途,Python 也是免費的。
開源正在成為軟件行業(yè)的一種發(fā)展趨勢,現(xiàn)在有很多商業(yè)軟件公司都開始將自己的產(chǎn)品變成開源的(例如 Java)。也許,Python 的開源正是它如此優(yōu)秀的原因之一,因為會有這么一群人,他們希望看到一個更加優(yōu)秀的 Python,從而為了這個目標,不斷地對 Python 進行創(chuàng)造,不斷地改進。
3、高級語言
Python 是高級語言,因此當使用 Python 語言編寫程序時,我們無需再考慮一些底層細節(jié)方面的問題。例如,如何管理程序使用的內(nèi)存等等。
4、解釋型語言
一個用編譯型語言(如 C 或 C++)寫的程序,可以從源文件轉換到一個計算機使用的語言。這個過程主要通過編譯器完成。當運行程序的時候,我們可以把程序從硬盤復制到內(nèi)存中并且運行。
而 Python 語言寫的程序,則不需要編譯成二進制代碼,可以直接從源代碼運行程序。在計算機內(nèi)部,由 Python 解釋器把源代碼轉換成字節(jié)碼的中間形式,然后再把它翻譯成計算機使用的機器語言并運行。
事實上,由于不再擔心如何編譯程序,使得使用 Python 變得更加簡單,我們只需要將 Python 程序復制到另外一臺計算機上,它就可以工作了。因此,Python 程序更加易于移植。
5、可移植性
由于 Python 是開源的,它已經(jīng)被移植到許多平臺上。如果能夠避免使用依賴系統(tǒng)的特性,那就意味著,所有 Python 程序都無需修改就可以在好多平臺上運行,包括 Linux 、Windows、FreeBSD、Solaris 等等,甚至還有 PocketPC、Symbian 以及 Google 基于 Linux 開發(fā)的 Android 平臺。
解釋型語言幾乎天生就是跨平臺的。Python 作為一門解釋型的語言,它天生具有跨平臺的特征,只要為平臺提供了相應的 Python 解釋器,Python 就可以在該平臺上運行。
6、面向對象
Python 既支持面向過程編程,也支持面向對象編程。在“面向過程”的語言中(如 C 語言),程序僅僅是由可重用代碼的函數(shù)構建起來的;而在“面向對象”的語言(如 C++)中,程序是由數(shù)據(jù)和功能組合而成的對象構建起來的。
與其他編程語言(如 C++ 和 Java)相比,Python 是以一種非常強大,而又簡單的方式實現(xiàn)的面向對象編程。
7、強大的功能
Python 強大的功能也許才是很多用戶支持 Python 的最重要的原因,從字符串處理到復雜的 3D 圖形編程,Python 借助擴展模塊都可以輕松完成。
實際上,Python 的核心模塊已經(jīng)提供了足夠強大的功能,使用 Python 精心設計的內(nèi)置對象可以完成許多功能強大的操作。
此外,Python 的社區(qū)也很發(fā)達,即使一些小眾的應用場景,Python 往往也有對應的開源模塊來提供解決方案。
8、可擴展性
Python 的可擴展性體現(xiàn)為它的模塊,Python 具有腳本語言中最豐富和強大的類庫,這些類庫覆蓋了文件 I/O、GUI、網(wǎng)絡編程、數(shù)據(jù)庫訪問、文本操作等絕大部分應用場景。
Python 可擴展性一個最好的體現(xiàn)是,當我們需要一段關鍵代碼運行的更快時,可以將其用 C 或 C++ 語言編寫,然后在 Python 程序中使用它們即可。
除了以上幾個特點之外,作為一個解釋型語言,Python 自然也有一些缺點,比如:
1、速度慢:Python 程序比 Java、C、C++ 等程序的運行效率都要慢。
2、源代碼加密困難:不像編譯型語言的源程序會被編譯成目標程序,Python 直接運行源程序,因此對源代碼加密比較困難。
舉幾個Python基礎編程范例:
一、題目:有1、2、3、4個數(shù)字,能組成多少個互不相同且無重復數(shù)字的三位數(shù)?都是多少??
1.程序分析:可填在百位、十位、個位的數(shù)字都是1、2、3、4。組成所有的排列后再去?
掉不滿足條件的排列。?
2.程序源代碼:
for i in range(1,5):
? ? for j in range(1,5):
? ? ? ? for k in range(1,5):
? ? ? ? ? ? if( i != k ) and (i != j) and (j != k):
? ? ? ? ? ? ? ? print i,j,k
二、題目:企業(yè)發(fā)放的獎金根據(jù)利潤提成。利潤(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,求應發(fā)放獎金總數(shù)??
1.程序分析:請利用數(shù)軸來分界,定位。注意定義時需把獎金定義成長整型?! ?
2.程序源代碼:
bonus1 = 100000 * 0.1
bonus2 = bonus1 + 100000 * 0.500075
bonus4 = bonus2 + 200000 * 0.5
bonus6 = bonus4 + 200000 * 0.3
bonus10 = bonus6 + 400000 * 0.15
空格
i = int(raw_input('input gain:\n'))
if i <= 100000:
? ? bonus = i * 0.1
elif i <= 200000:
? ? bonus = bonus1 + (i - 100000) * 0.075
elif i <= 400000:
? ? bonus = bonus2 + (i - 200000) * 0.05
elif i <= 600000:
? ? bonus = bonus4 + (i - 400000) * 0.03
elif i <= 1000000:
? ? bonus = bonus6 + (i - 600000) * 0.015
else:
? ? bonus = bonus10 + (i - 1000000) * 0.01
print 'bonus = ',bonus
三、題目:一個整數(shù),它加上100后是一個完全平方數(shù),再加上168又是一個完全平方數(shù),請問該數(shù)是多少??
1.程序分析:在10萬以內(nèi)判斷,先將該數(shù)加上100后再開方,再將該數(shù)加上268后再開方,如果開方后?
的結果滿足如下條件,即是結果。請看具體分析:?
2.程序源代碼:
include "math.h"
main()
{
long int i,x,y,z;
for (i=1;i<100000;i++)
{ x=sqrt(i+100); /*x為加上100后開方后的結果*/
y=sqrt(i+268); /*y為再加上168后開方后的結果*/
if(x*x==i+100&&y*y==i+268)/*如果一個數(shù)的平方根的平方等于該數(shù),這說明此數(shù)是完全平方數(shù)*/
printf("\n%ld\n",i);
}
}?
'''
import math
for i in range(10000):
? ? #轉化為整型值
? ? x = int(math.sqrt(i + 100))
? ? y = int(math.sqrt(i + 268))
? ? if(x * x == i + 100) and (y * y == i + 268):
? ? ? ? print i
四、題目:輸入某年某月某日,判斷這一天是這一年的第幾天??
1.程序分析:以3月5日為例,應該先把前兩個月的加起來,然后再加上5天即本年的第幾天,特殊?
情況,閏年且輸入月份大于3時需考慮多加一天。?
2.程序源代碼:
year = int(raw_input('year:\n'))
month = int(raw_input('month:\n'))
day = int(raw_input('day:\n'))
空格
months = (0,31,59,90,120,151,181,212,243,273,304,334)
if 0 <= month <= 12:
? ? sum = months[month - 1]
else:
? ? print 'data error'
sum += day
leap = 0
if (year % 400 == 0) or ((year % 4 == 0) and (year % 100 != 0)):
? ? leap = 1
if (leap == 1) and (month > 2):
? ? sum += 1
print 'it is the %dth day.' % sum
五、題目:輸入三個整數(shù)x,y,z,請把這三個數(shù)由小到大輸出。?
1.程序分析:我們想辦法把最小的數(shù)放到x上,先將x與y進行比較,如果x>y則將x與y的值進行交換,?
然后再用x與z進行比較,如果x>z則將x與z的值進行交換,這樣能使x最小。?
2.程序源代碼:
l = []
for i in range(3):
? ? x = int(raw_input('integer:\n'))
? ? l.append(x)
l.sort()
print l
六、題目:用*號輸出字母C的圖案。?
1.程序分析:可先用’*’號在紙上寫出字母C,再分行輸出。?
2.程序源代碼:
print 'Hello Python world!\n'
print '*' * 10
for i in range(5):
? ? print '* ? ? ? ?*'
print '*' * 10
print '*\n' * 6
七、題目:輸出特殊圖案,請在c環(huán)境中運行,看一看,Very Beautiful!?
1.程序分析:字符共有256個。不同字符,圖形不一樣。 ?
2.程序源代碼:
a = 176
b = 219
print chr(b),chr(a),chr(a),chr(a),chr(b)
print chr(a),chr(b),chr(a),chr(b),chr(a)
print chr(a),chr(a),chr(b),chr(a),chr(a)
print chr(a),chr(b),chr(a),chr(b),chr(a)
print chr(b),chr(a),chr(a),chr(a),chr(b)
八、題目:輸出9*9口訣。?
1.程序分析:分行與列考慮,共9行9列,i控制行,j控制列。?
2.程序源代碼:
include "stdio.h"
main()
{
int i,j,result;
printf("\n");
for (i=1;i<10;i++)
{ for(j=1;j<10;j++)
{
result=i*j;
printf("%d*%d=%-3d",i,j,result);/*-3d表示左對齊,占3位*/
}
printf("\n");/*每一行后換行*/
}
}
for i in range(1,10):
? ? for j in range(1,10):
? ? ? ? result = i * j
? ? ? ? print '%d * %d = % -3d' % (i,j,result)
? ? print ''
九、題目:要求輸出國際象棋棋盤。?
1.程序分析:用i控制行,j來控制列,根據(jù)i+j的和的變化來控制輸出黑方格,還是白方格。?
2.程序源代碼:
include "stdio.h"
main()
{
int i,j;
for(i=0;i<8;i++)
{
for(j=0;j<8;j++)
if((i+j)%2==0)
printf("%c%c",219,219);
else
printf(" ");
printf("\n");
}
}
import sys
for i in range(8):
? ? for j in range(8):
? ? ? ? if(i + j) % 2 == 0:
? ? ? ? ? ? sys.stdout.write(chr(219))
? ? ? ? ? ? sys.stdout.write(chr(219))
? ? ? ? else:
? ? ? ? ? ? sys.stdout.write(' ')
? ? print ''
十、題目:將一個正整數(shù)分解質因數(shù)。例如:輸入90,打印出90=2*3*3*5。
1.程序分析:對n進行分解質因數(shù),應先找到一個最小的質數(shù)k,然后按下述步驟完成:?
(1)如果這個質數(shù)恰等于n,則說明分解質因數(shù)的過程已經(jīng)結束,打印出即可。?
(2)如果n<>k,但n能被k整除,則應打印出k的值,并用n除以k的商,作為新的正整數(shù)你n,?
重復執(zhí)行第一步。?
(3)如果n不能被k整除,則用k+1作為k的值,重復執(zhí)行第一步。
2.程序源代碼:
from sys import stdout
n = int(raw_input("input number:\n"))
print "n = %d" % n
for i in range(2,n + 1):
? ? while n != i:
? ? ? ? if n % i == 0:
? ? ? ? ? ? stdout.write(str(i))
? ? ? ? ? ? stdout.write("*")
? ? ? ? ? ? n = n / i
? ? ? ? else:
? ? ? ? ? ? break
print "%d" % n