反转 Python 整数的位

Reversing bits of Python integer(反转 Python 整数的位)
本文介绍了反转 Python 整数的位的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

给定一个十进制整数(例如 65),如何反转 Python 中的底层位?即以下操作:

Given a decimal integer (eg. 65), how does one reverse the underlying bits in Python? i.e.. the following operation:

65 → 01000001 → 10000010 → 130

看来这个任务可以分解为三个步骤:

It seems that this task can be broken down into three steps:

  1. 将十进制整数转换为二进制表示
  2. 反转位
  3. 转换回十进制

第 2 步和第 3 步看起来非常简单(请参阅 this 和 this SO 问题与步骤#2) 相关,但我被困在步骤#1.第 1 步的问题是检索完整的十进制表示并填充零(即 65 = 01000001,而不是 1000001).

Steps #2 and 3 seem pretty straightforward (see this and this SO question related to step #2), but I'm stuck on step #1. The issue with step #1 is retrieving the full decimal representation with filling zeros (ie. 65 = 01000001, not 1000001).

我四处寻找,但似乎找不到任何东西.

I've searched around, but I can't seem to find anything.

推荐答案

int('{:08b}'.format(n)[::-1], 2)

您可以指定任何填充长度来代替 8.如果您想要真正花哨,

You can specify any filling length in place of the 8. If you want to get really fancy,

b = '{:0{width}b}'.format(n, width=width)
int(b[::-1], 2)

让您以编程方式指定宽度.

lets you specify the width programmatically.

这篇关于反转 Python 整数的位的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)
Grouping pandas DataFrame by 10 minute intervals(按10分钟间隔对 pandas 数据帧进行分组)