返回顶部
首页 > 资讯 > 后端开发 > Python >Python如何实现一个位图索引
  • 110
分享到

Python如何实现一个位图索引

Python 2023-05-16 21:05:25 110人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

代码如下:class Bitmap(object): def __init__(self, max): self.size = self.calcElemIndex(max, True) self.array = [0 for

代码如下:

class Bitmap(object):
	def __init__(self, max):
		self.size  = self.calcElemIndex(max, True)
		self.array = [0 for i in range(self.size)]
	def calcElemIndex(self, num, up=False):
		'''up为True则为向上取整, 否则为向下取整'''
		if up:
			return int((num + 31 ) / 31) #向上取整
		return num / 31
		
	def calcBitIndex(self, num):
		return num % 31
		
	def set(self, num):
		elemIndex = int(self.calcElemIndex(num))
		byteIndex = self.calcBitIndex(num)
		elem      = self.array[elemIndex]
		self.array[elemIndex] = elem | (1 << byteIndex)	
		
	def clean(self, i):
		elemIndex = int(self.calcElemIndex(i))
		byteIndex = self.calcBitIndex(i)
		elem      = self.array[elemIndex]
		self.array[elemIndex] = elem & (~(1 << byteIndex))
	def test(self, i):
		elemIndex =int(self.calcElemIndex(i))
		byteIndex = self.calcBitIndex(i)
		if self.array[elemIndex] & (1 << byteIndex):
			return True
		return False
MAX = 879
suffle_array = [45, 2, 78, 35, 67, 90, 879, 0, 340, 123, 46]
result       = []
bitmap = Bitmap(MAX)
for num in suffle_array:
	bitmap.set(num)
for i in range(MAX + 1):
	if bitmap.test(i):
		result.append(i)
print ('原始数组为:    %s' % suffle_array)
print ('排序后的数组为: %s' % result)

以上就是python如何实现一个位图索引的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: Python如何实现一个位图索引

本文链接: https://lsjlt.com/news/210585.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Python如何实现一个位图索引
    代码如下:class Bitmap(object): def __init__(self, max): self.size = self.calcElemIndex(max, True) self.array = [0 for ...
    99+
    2023-05-16
    Python
  • Python中怎么实现一个位图索引
    Python中怎么实现一个位图索引,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。class Bitmap(object):def __ini...
    99+
    2023-06-02
  • oracle位图索引的字段如何修改
    要修改Oracle位图索引的字段,可以通过以下步骤进行操作: 确定要修改的位图索引所属的表名和字段名。 首先,使用以下语句禁...
    99+
    2023-10-25
    oracle
  • Python 索引:如何实现实时打包?
    Python 是一种高级编程语言,具有简单易学、可读性强、开发效率高等优点。在 Python 中,索引是一种非常重要的数据结构,它可以用来快速查找和获取数据。本文将介绍如何使用 Python 实现实时打包。 一、什么是实时打包? 实时打包...
    99+
    2023-10-29
    索引 实时 打包
  • 浅谈用Python实现一个大数据搜索引擎
    搜索是大数据领域里常见的需求。Splunk和ELK分别是该领域在非开源和开源领域里的领导者。本文利用很少的Python代码实现了一个基本的数据搜索功能,试图让大家理解大数据搜索的基本原理。 布隆过滤器 (B...
    99+
    2022-06-04
    浅谈 搜索引擎 数据
  • 使用Python怎么实现一个索引排序功能
    使用Python怎么实现一个索引排序功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。import requestsimport redef Ne...
    99+
    2023-06-14
  • Python实战之手写一个搜索引擎
    目录一、前言二、工作流程三、数据模块四、索引模块五、搜索模块一、前言 这篇文章,我们将会尝试从零搭建一个简单的新闻搜索引擎 当然,一个完整的搜索引擎十分复杂,这里我们只介绍其中最为核...
    99+
    2024-04-02
  • MySQL中怎么实现一个搜索引擎
    本篇文章为大家展示了MySQL中怎么实现一个搜索引擎,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。前言 只有Innodb和myisam存储引擎能用全文索引...
    99+
    2024-04-02
  • python如何实现一个ORM
    这篇文章给大家分享的是有关python如何实现一个ORM的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。python有哪些常用库python常用的库:1.requesuts;2.scrapy;3.pillow;4....
    99+
    2023-06-14
  • 如何实现MySQL的索引
    MySQL中索引分三类:B+树索引、Hash索引、全文索引。InnoDB存储引擎中用的是B+树索引。要介绍B+树索引,不得不提二叉查找树、平衡二叉树和B树这三种数据结构。B+树是从它...
    99+
    2024-04-02
  • 怎么在mysql中实现一个联合索引
    这篇文章将为大家详细讲解有关怎么在mysql中实现一个联合索引,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。联合索引联合索引的定义为(MySQL):ALTER TABLE ...
    99+
    2023-06-14
  • MySQL位图索引如何解决用户画像问题
    这篇文章主要介绍了MySQL位图索引如何解决用户画像问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。用户画像的原始表,有一亿记录,100多...
    99+
    2024-04-02
  • Python 如何实现重定向以及实时索引?
    Python 是一种非常流行的编程语言,它可以用于各种不同的应用场景。其中,Python 的重定向和实时索引功能在许多应用程序中非常有用。在本文中,我们将学习如何使用 Python 实现重定向和实时索引。 重定向是一种将程序输出发送到不同地...
    99+
    2023-10-24
    重定向 实时 索引
  • python如何输入一个三位数,输出百位、十位和个位
    这篇文章主要介绍了python如何输入一个三位数,输出百位、十位和个位,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。方法:1、使用input()接收从键盘输入的一个三位数,返...
    99+
    2023-06-14
  • 如何用Vue实现一个渲染引擎
    这篇文章主要介绍“如何用Vue实现一个渲染引擎”,在日常操作中,相信很多人在如何用Vue实现一个渲染引擎问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何用Vue实现一个渲染...
    99+
    2024-04-02
  • 如何在Python中实现二维码的索引和检索?
    二维码已经成为了现代生活中不可或缺的一部分。从商业应用到个人生活,我们都可以看到二维码的身影。在Python中实现二维码的索引和检索是一个有趣且有用的挑战。在本篇文章中,我们将介绍如何使用Python实现二维码的索引和检索,并提供一些演示代...
    99+
    2023-09-09
    二维码 开发技术 索引
  • python如何实现有下标索引的枚举
    这篇文章主要为大家展示了“python如何实现有下标索引的枚举”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“python如何实现有下标索引的枚举”这篇文章吧。有...
    99+
    2024-04-02
  • 基于 Mysql 实现一个简易版搜索引擎
    目录基于 Mysql 实现一个搜索引擎一、ngram 全文解析器二、创建全文索引1、建表时创建全文索引2、通过 alter table 方式3、通过 create index 方式三...
    99+
    2024-04-02
  • PHP中怎么实现一个站内搜索引擎
    这篇文章将为大家详细讲解有关PHP中怎么实现一个站内搜索引擎,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。PHP实现站内搜索引擎的具体代码:<   inc...
    99+
    2023-06-17
  • Mysql索引覆盖如何实现
    这篇“Mysql索引覆盖如何实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Mysql索引覆盖如何实现”文章吧。1.什么是...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作