Ⅰ python語言中,表達式int(-4.3)的值是
結果是-4
對正數是向下取整,對負數是向上取整。
學python的一個缺點就是對數據類型的基礎理解比較少,
你可以用二進制來理解下,舉一個有符號的二進制為例子:
對於無符號的0b000~0b111來說分別有
0b000=0;
0b001=1;
0b010=2;
0b011=3;
0b100=4;
0b101=5;
0b110=6;
0b111=7;
比如uint就是int的無符號形式。
當相同數據為有符號形式時變為:
0b000=0;
0b001=1;
0b010=2;
0b011=3;
0b100=-4;
0b101=-3;
0b110=-2;
0b111=-1;
(參考原碼、反碼、補碼)
所以根據這個規則,對float,double等數字是同理,在floor時將有符號位進行省略,如以下位運算(>>):
0b000>>1=0b000
0b001>>1=0b000
有0->0和1->0
0b010>>1=0b001
0b011>>1=0b001
有2->1和3->1
按照這個丟失精度的方法計算負數呢?
0b111>>1=0b111
0b110>>1=0b111
0b101>>1=0b110
0b100>>1=0b110
可知:
-1->-1與-2->-1
-3->-2與-4->-2
所以對負數的floor會向上取整,因為丟失精度的方法是直接根據小數點截斷的。
Ⅱ Python中lw=2是什麼意思
Python中lw=2的意思是:
w//2 求模(求商)
比如1 + 20//3 即 1 + 6得到7
// 表示取整除 - 返回商的整數部分(向下取整)
Python 在今年已經成為世界上最受歡迎的語言,C 和 Java 分別位居第二和第三位。
Ⅲ python中四捨五入函數取整為什麼要加減0.5
是利用原來的向下取整的機制如果原來是<0.5的,那加上0.5還是沒進位。
實際上Python的round()函數可以接受兩個參數round(value,ndigits),第一個參數為實際操作數,第二個參數為實際保留幾位,如果第二個參數不填,則默認保留到整數位。
Python3.X對於浮點數默認的是提供17位數字的精度。
Ⅳ 基本的python內置函數int(x)的作用是
內置函數,在python幫助文檔中:Build-in Functions
在Python提示符下,輸入下面語句,就會顯示Python提供的內置函數列表
>>>dir('__builtins__')
abs(_) 內置函數,絕對值或復數的模。
chr() 以單位元組整數為參數,返回一個單字元的字元串,其內容是與之對於的ASCII字元。如chr(69)返回'E'。
cmp() 比較字元串,cmp('Xiao','Jian')返回1
coerce() (可以看成一個數值類型轉換函數)有兩個參數,都是數字,返回這兩個數字的一個列表,將這兩個數字的數據類型統一。如coerce(1,2j),返回(1+0j,2j)
complex() 內置函數,把……轉換成復數,如complex('2')返回(2+0j),complex('2+3j')返回(2+3j)。
divmod() 內置函數,有兩個參數,返回(商,余數)。如divmod(10,2.5),返回(4.0,0.0)。
filter(function,list) 把函數應用於list中的每一項,並返回 從函數中返回真值的項。註:function可以為None,此時刪除list中的0或空項。
float() 內置函數,把……轉換成浮點數。
floor() 在math模塊內,需要import math。向下取整,即向x軸負方向取整。如math.floor(1.9)返回1,math.floor(-2.5)返回-3。
hash() 散列功能,詞典鍵的最精確功能需求是它一定是可散列的。對象的散列值是半唯一的、內部生成的數字,它可用於快速比較。
int() 內置函數,把字元串或者小數轉換為一個整數。直接去掉小數部分。如int(5.3)返回5,int('5')返回5。
len(x) 序列x的長度
long() 內置函數,把數字 或 代表整數的字元串 轉換成長整型
map(function,list[,list,...])
max() 找出字元串中最大的字元。如:min('find the minimum character'),返回' ',即空格。
min() 找出字元串中最小的字元。如:max('find the maximum character'),返回'x'。
oct() 將十進制數轉換成八進制,再變成字元。
ord() 參數是單個的ASCII字元,返回該ASCII字元對應的整數值,如ord('a')返回97。
pow() 內置函數,乘方。如果有第三個參數,則表示乘方的結果對第三參數取余,如pow(2,3)返回8,pow(2,3,4)返回0。
print 輸出到窗口
range() 生成一個向量,例如range(m,n,d),從m到n,步長為d;range(m)則生成0:m-1,步長為1的向量。
raw_input() 輸入函數,參數為字元串,作為輸入時的提示語句。返回值為字元串。
rece(func)
round() 內置函數,對數字進行四捨五入,第二個參數表示精確到小數點後指定的位數,默認值為0。如round(2.4)返回2,round(1.398,2)返回1.40。
type() 返回某數據的類型
Ⅳ Python筆記-取模運算%
對於該算術運算符: % ,取模運算存在如下定理:
對於一個正整數 而言,一定存在等式 ,代表 可以被拆分成最多 個 並且餘下一個 ,此時稱 。
例如:正整數 17,存在等式 17 = 3 * 5 + 2,即 17 % 5 = 2.
這里介紹一下數學中的一種運算, 取余運算 。
兩者在對正整數的運算中完全沒有區別,但是對於負整數的運算,則會存在一定的區別。
但是要記住下面這句話,就可以很好的進行區分:
取余公式中的k要向0靠攏,也就是如果大於等於0,那就要向下取整;如果小於0,那就要向上取整。
取模公式中的k要向負無窮靠攏,不管什麼情況,都是向下取整。
或者是
向上取整 math.ceil() 可以理解成 要選擇大於等於該數值的整數部分的最小整數;
向下取整 math.floor() 可以理解成 要選擇小於等於該數值的整數部分的最大整數。
也就是:
下面做些實際運算,加深一下印象:
Ⅵ Python幾種取整的方法
向下取整
int(3.75)
四捨五入
round(3.75)
向上取整
math.ceil(3.75)
分離整數和小數
math.modf(3.75)