Home Backend Development Python Tutorial A brief discussion on dictionaries and hash tables in Python and the resolution of hash conflicts

A brief discussion on dictionaries and hash tables in Python and the resolution of hash conflicts

Oct 09, 2018 pm 02:47 PM
python

The content of this article is about a brief discussion of dictionaries and hash tables in Python and the resolution of hash conflicts. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you.

Python uses hash tables to implement dict.

A hash table is actually a sparse array (an array that always has blank elements is called a sparse array). In general books, the units in a hash table are usually called buckets. exist dict In the hash table, each key-value pair occupies a table element, and each table element has two parts, one is a reference to the key, and the other is a reference to the value. Because each table cell is the same size, you can read a table cell by offset.

Python will try to ensure that about one-third of the table elements are empty. When this threshold is almost reached, it will expand and copy the original hash table to a larger hash table. .

If you want to put an object into a hash table, you must first calculate the hash value of the element key. This requires that the key must be hashable.

A hashable object must meet the following conditions:

Support the hash() function, and the hash value obtained through the __hash__() method is unchanged.

Supports equality detection through the __eq__() method.

If a == b is true, then hash(a) == hash(b) is also true.

The following mainly explains the hash table algorithm.

To get the key The value search_value corresponding to search_key, Python will first call hash(search_key) to calculate search_key The hash value of the value, the lowest few digits of this value are used as offsets, and the table element is searched in the hash table (the specific number depends on the size of the current hash table). If the found table element is empty, KeyError is thrown Exception; if it is not empty, there will be a pair of found_key:found_value in the table element, check search_key and found_key Whether they are equal, if so, return found_value. If they are not equal, this situation is called a hash collision.

In order to solve the hash conflict, the algorithm will take a few more bits in the hash value, then process it with a special method, and use the new value obtained as an offset to search in the hash table table element, if the found table element is empty, a KeyError exception will also be thrown; if it is not empty, compare the keys to see if they are consistent, and return the corresponding value if they are consistent; if a hash conflict is found, repeat the above steps.

Adding a new element is almost the same as the above process, except that when an empty table element is found, the new element will be put in. If it is not empty, the hash will be repeated and the search will continue.

When to go When a new element is added to the dict and a hash conflict occurs, the new element may be arranged to be stored in another location. So the following situation will happen: dict([key1, value1], [key2, value2]) and dict([key2, value2], [key1, value1]) Two dictionaries are equal when compared, but if the hashes of key1 and key2 conflict, the order of the two keys in the dictionary is different.

Whenever, go Add new keys to dict, python The parser may decide to expand the dictionary. The result of expansion is to create a larger hash table and add existing elements in the dictionary to the new hash table. New hash conflicts may occur during this process, causing the order of keys in the new hash table to change. What happens if you iterate over a dictionary while adding new keys to it? Unfortunately, the capacity was expanded. Unfortunately, the order of the keys changed, and then orz.

Since the hash table must be sparse, its space consumption must be much larger. This is a typical space-for-time trade-off.

The above is the detailed content of A brief discussion on dictionaries and hash tables in Python and the resolution of hash conflicts. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to open xml format How to open xml format Apr 02, 2025 pm 09:00 PM

Use most text editors to open XML files; if you need a more intuitive tree display, you can use an XML editor, such as Oxygen XML Editor or XMLSpy; if you process XML data in a program, you need to use a programming language (such as Python) and XML libraries (such as xml.etree.ElementTree) to parse.

Is there any mobile app that can convert XML into PDF? Is there any mobile app that can convert XML into PDF? Apr 02, 2025 pm 08:54 PM

An application that converts XML directly to PDF cannot be found because they are two fundamentally different formats. XML is used to store data, while PDF is used to display documents. To complete the transformation, you can use programming languages ​​and libraries such as Python and ReportLab to parse XML data and generate PDF documents.

Is the conversion speed fast when converting XML to PDF on mobile phone? Is the conversion speed fast when converting XML to PDF on mobile phone? Apr 02, 2025 pm 10:09 PM

The speed of mobile XML to PDF depends on the following factors: the complexity of XML structure. Mobile hardware configuration conversion method (library, algorithm) code quality optimization methods (select efficient libraries, optimize algorithms, cache data, and utilize multi-threading). Overall, there is no absolute answer and it needs to be optimized according to the specific situation.

How to convert XML files to PDF on your phone? How to convert XML files to PDF on your phone? Apr 02, 2025 pm 10:12 PM

It is impossible to complete XML to PDF conversion directly on your phone with a single application. It is necessary to use cloud services, which can be achieved through two steps: 1. Convert XML to PDF in the cloud, 2. Access or download the converted PDF file on the mobile phone.

How to modify comment content in XML How to modify comment content in XML Apr 02, 2025 pm 06:15 PM

For small XML files, you can directly replace the annotation content with a text editor; for large files, it is recommended to use the XML parser to modify it to ensure efficiency and accuracy. Be careful when deleting XML comments, keeping comments usually helps code understanding and maintenance. Advanced tips provide Python sample code to modify comments using XML parser, but the specific implementation needs to be adjusted according to the XML library used. Pay attention to encoding issues when modifying XML files. It is recommended to use UTF-8 encoding and specify the encoding format.

Does XML modification require programming? Does XML modification require programming? Apr 02, 2025 pm 06:51 PM

Modifying XML content requires programming, because it requires accurate finding of the target nodes to add, delete, modify and check. The programming language has corresponding libraries to process XML and provides APIs to perform safe, efficient and controllable operations like operating databases.

Recommended XML formatting tool Recommended XML formatting tool Apr 02, 2025 pm 09:03 PM

XML formatting tools can type code according to rules to improve readability and understanding. When selecting a tool, pay attention to customization capabilities, handling of special circumstances, performance and ease of use. Commonly used tool types include online tools, IDE plug-ins, and command-line tools.

Is there a free XML to PDF tool for mobile phones? Is there a free XML to PDF tool for mobile phones? Apr 02, 2025 pm 09:12 PM

There is no simple and direct free XML to PDF tool on mobile. The required data visualization process involves complex data understanding and rendering, and most of the so-called "free" tools on the market have poor experience. It is recommended to use computer-side tools or use cloud services, or develop apps yourself to obtain more reliable conversion effects.

See all articles