洗牌利器——random.shuffle()函数
在Python中,非十进制数字的表示方式为:
二进制:前面加0b,如0b1001
八进制:前面加0o,如0o3562
十六进制:前面加0x,如0x2af3(字母a-f大小写随意)
不同进制数字可直接进行数学计算,结果返回十进制:
x=0b100 #二进制的4
y=0xa #十六进制的10
print(x+y,type(x),type(y))
执行结果:14 <class 'int'> <class 'int'>
下面按照不同的进制说明相关的转换方法:
bin(binary:其他进制数字→0b开头的二进制字符串)
x=bin(100)
y=bin(0x2a)
print(x,type(x))
print(y,type(y))
执行结果:
0b1100100 <class 'str'>
0b101010 <class 'str'>
oct(octonary:其他进制数字→0o开头的八进制字符串)
x=oct(100)
y=oct(0b100)
print(x,type(x))
print(y,type(y))
执行结果:
0o144 <class 'str'>
0o4 <class 'str'>
hex(hexadecimal:其他进制数字→0x开头的十六进制字符串)
x=hex(100)
y=hex(0b100)
print(x,type(x))
print(y,type(y))
执行结果:
0x64 <class 'str'>
0x4 <class 'str'>
int(integer:三种情况→十进制数字)
情况一:0?开头的其他进制数字→十进制数字
a=0b100
b=0xf
print(int(a))
print(int(b))
执行结果:
4
15
情况二:0?开头的其他进制字符串→十进制数字
a='0b100'
b='0xf'
print(int(a,base=0))
print(int(b,0))
执行结果:
4
15
情况三:不带0?的其他进制字符串→十进制数字
a='100'
b='f'
print(int(a,base=2))
print(int(b,16))
执行结果:
4
15
int()的第一个参数 | int()的第二个参数 |
---|---|
0?开头的其他进制数字 | 不输 |
0?开头的其他进制字符串 | 必输base=0,或简写为0 |
不带0?的其他进制字符串 | 必输base=进制数,或简写为进制数 |
注意:bin、oct、hex都直接接一个参数且输出的都是字符串。int与这三个不同,它分三种情况,接一个或两个参数,且输出结果是数字。
x=0b101
y=str(x)
print(x,type(x))
print(y,type(y))
执行结果:
5 <class 'int'>
5 <class 'str'>
注意:直接手输的0b、0o、0x开头的非十进制数字的数据类型都是int,对其print或转为字符串时,会先转化成十进制再转成字符串
补充:笔者自行推导的int2bin、bin2int
基于二进制与十进制的转化关系,笔者自己推导了输入、输出均为十进制数字的int2bin、bin2int函数:
int2bin:十进制转二进制(输入、输出均为十进制数字,如将十进制的7转换为十进制的111)
def int2bin(x):
s=''
while x>0:
s=s+str(x % 2)
x=x//2
return int(s[::-1])
print(int2bin(7))
bin2int:二进制转十进制(输入、输出均为十进制数字,如将十进制的111转换为十进制的7)
def bin2int(x):
y=str(x)
power = len(y)-1
s=0
for i in y:
s=s+int(i)*(2**power)
power-=1
return s
print(bin2int(111))
洗牌利器——random.shuffle()函数的更多相关文章
- [转]完美洗牌(Perfect Shuffle)问题
[转]原博文地址:https://github.com/julycoding/The-Art-Of-Programming-By-July/blob/master/ebook/zh/02.09.md ...
- 随机洗牌算法Knuth Shuffle和错排公式
Knuth随机洗牌算法:譬如现在有54张牌,如何洗牌才能保证随机性.可以这么考虑,从最末尾一张牌开始洗,对于每一张牌,编号在该牌前面的牌中任意一张选一张和当前牌进行交换,直至洗到第一张牌为止.参考代码 ...
- np.random.random()系列函数
1.np.random.random()函数参数 np.random.random((1000, 20)) 上面这个就代表生成1000行 20列的浮点数,浮点数都是从0-1中随机. 2.numpy.r ...
- np.random.random()函数 参数用法以及numpy.random系列函数大全
原文作者:aircraft 原文链接:https://www.cnblogs.com/DOMLX/p/9751471.html 1.np.random.random()函数参数 np.random.r ...
- 【转】np.random.random()函数 参数用法以及numpy.random系列函数大全
转自:https://www.cnblogs.com/DOMLX/p/9751471.html 1.np.random.random()函数参数 np.random.random((1000, 20) ...
- python 练习洗牌
生成随机数需要引入random模块,学习下random模块中常用的几个函数: random.random() 用于生成一个0到1的随机符点数: 0 <= n < 1.0 random.un ...
- 【CUDA 基础】5.6 线程束洗牌指令
title: [CUDA 基础]5.6 线程束洗牌指令 categories: - CUDA - Freshman tags: - 线程束洗牌指令 toc: true date: 2018-06-06 ...
- 文本数据挖掘---课后作业shuffle函数洗牌C++
题目: 代码如下:#include <iostream> #include <random> #include <algorithm> #include <v ...
- 洗牌算法及 random 中 shuffle 方法和 sample 方法浅析
对于算法书买了一本又一本却没一本读完超过 10%,Leetcode 刷题从来没坚持超过 3 天的我来说,算法能力真的是渣渣.但是,今天决定写一篇跟算法有关的文章.起因是读了吴师兄的文章<扫雷与算 ...
随机推荐
- 计算几何-UVa10652
This article is made by Jason-Cow.Welcome to reprint.But please post the article's address. 题意见白书,P2 ...
- configure: error: no acceptable C compiler found in $PATH 解决
在安装keepalived时报错 ./configure --prefix=/usr/local/ccbase/keepalived-2.0.15 && make && ...
- 【渗透测试】ZipperDown 漏洞分析
0x01 漏洞危害 1. 在使用 HTTP 下载 zip 包并使用有问题的第三方库 unzip 时,攻击者通过劫持 HTTP 流量,可以导致 APP 下载一个恶意的 zip 包,在解压 zip 包时可 ...
- 类型type:clusterip和service内部的关系
类型type:clusterip和service内部的关系 待办 https://stackoverflow.com/questions/41509439/whats-the-difference-b ...
- 主席树板子 p2104
#include<cstdio> #include<algorithm> #include<vector> using namespace std; ; int n ...
- js中map和filter方法,以及search方法
链接:https://blog.51cto.com/11871779/2126561 search方法: 介绍: search() 方法用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符 ...
- 微信小程序遮罩层覆盖input失效
问题:微信小程序中,我们常使用遮罩层,如点击按钮弹出下拉框.弹框等等.若在遮罩层下存在input.textarea.canvas.camera.map.video等标签时,会出现遮罩层覆盖失效的问题. ...
- CF1272C
Recently, Norge found a string s=s1s2…sns=s1s2…sn consisting of nn lowercase Latin letters. As an ex ...
- go基础_切片
切片创建方式 1.通过数组创建 2.通过内置函数make创建 切片允许的操作 1.追加元素 2.通过内置函数make创建 package main import "fmt" fun ...
- 【C语言】输入一个字符串,统计其中的单词个数,将第一个单词的首字母改为大写,并输出改写后的字符串
#include<stdio.h> int main() { ]; ; printf("请输入一串字符:"); gets_s(a); ; a[i] != '\0'; i ...