Table of Contents
Character sets and layers: efficiently generate unique permutations
Home Backend Development PHP Tutorial How to generate a permutation combination that does not repeat and does not contiguous identical characters based on a given character set and number of layers?

How to generate a permutation combination that does not repeat and does not contiguous identical characters based on a given character set and number of layers?

Apr 01, 2025 am 06:18 AM
python git arrangement

How to generate a permutation combination that does not repeat and does not contiguous identical characters based on a given character set and number of layers?

Character sets and layers: efficiently generate unique permutations

This article explores how to generate a permutation combination without duplicates and without consecutive identical characters based on a given character set and number of layers. For example, the character set {a, b}, the three-layer permutation combination should contain aab, aba, abb, baa, bab, bba, etc., but not aaa, bbb and other consecutive repeated characters. This requires algorithms to handle deduplication and avoid continuous duplication of characters.

The core challenge is to design an algorithm that can adapt to different character sets and layers and efficiently generate permutations that meet the criteria. This article will introduce two methods: digital replacement method and backtracking method.

Method 1: Digital replacement method

This method treats the permutation combination as an m-digit number (m is the character set size). For example, the character set {a, b} corresponds to a binary number. 00 represents aa, 01 represents ab, and so on. By traversing all m-digit numbers and replacing characters, you can get all possible combinations. To avoid continuous identical characters, specific m-digit numbers need to be excluded, such as numbers where all bits are the same.

Python code example:

 def solve_digit(arr, m, allow_all_same=False):
    res, cur = [], [''] * m
    n = len(arr)
    all_same_num = 0
    for _ in range(m):
        all_same_num = all_same_num * n 1
    for d in range(n ** m):
        if allow_all_same or d % all_same_num != 0:
            for i in range(m - 1, -1, -1):
                cur[i] = arr[d % n]
                d //= n
            res.append(''.join(cur))
    Return res

print(solve_digit('ab', 2)) # ['ab', 'ba']
print(solve_digit('ab', 2, True)) # ['aa', 'ab', 'ba', 'bb']
print(solve_digit('ab', 3)) # ['aab', 'aba', 'abb', 'baa', 'bab', 'bba']
print(solve_digit('abc', 2)) # ['ab', 'ac', 'ba', 'bc', 'ca', 'cb']
Copy after login

Method 2: Backtracking method

Backtrace is a recursive algorithm that finds results by trying all possible combinations. Add a character to the current combination at each step and recursively generates longer combinations. At the same time, it is necessary to track whether the previous characters are the same to avoid combinations that do not meet the conditions.

Python code example:

 def solve_backtracking(arr, m, allow_all_same=False):
    res, cur = [], [''] * m

    def dfs(i, same):
        if i == m:
            If not same:
                res.append(''.join(cur))
            Return
        for a in arr:
            cur[i] = a
            dfs(i 1, same and a == cur[i - 1])

    for a in arr:
        cur[0] = a
        dfs(1, not allow_all_same)

    Return res

print(solve_backtracking('AB', 2)) # ['AB', 'BA']
print(solve_backtracking('AB', 2, True)) # ['AA', 'AB', 'BA', 'BB']
print(solve_backtracking('AB', 3)) # ['AAB', 'ABA', 'ABB', 'BAA', 'BAB', 'BBA']
print(solve_backtracking('ABC', 2)) # ['AB', 'AC', 'BA', 'BC', 'CA', 'CB']
Copy after login

Both methods can solve the problem. The digital replacement method is more efficient and the backtracking method is easier to understand. Which method to choose depends on the specific application scenario and personal preferences.

The above is the detailed content of How to generate a permutation combination that does not repeat and does not contiguous identical characters based on a given character set and number of layers?. 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

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

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)

PHP and Python: Different Paradigms Explained PHP and Python: Different Paradigms Explained Apr 18, 2025 am 12:26 AM

PHP is mainly procedural programming, but also supports object-oriented programming (OOP); Python supports a variety of paradigms, including OOP, functional and procedural programming. PHP is suitable for web development, and Python is suitable for a variety of applications such as data analysis and machine learning.

Choosing Between PHP and Python: A Guide Choosing Between PHP and Python: A Guide Apr 18, 2025 am 12:24 AM

PHP is suitable for web development and rapid prototyping, and Python is suitable for data science and machine learning. 1.PHP is used for dynamic web development, with simple syntax and suitable for rapid development. 2. Python has concise syntax, is suitable for multiple fields, and has a strong library ecosystem.

PHP and Python: A Deep Dive into Their History PHP and Python: A Deep Dive into Their History Apr 18, 2025 am 12:25 AM

PHP originated in 1994 and was developed by RasmusLerdorf. It was originally used to track website visitors and gradually evolved into a server-side scripting language and was widely used in web development. Python was developed by Guidovan Rossum in the late 1980s and was first released in 1991. It emphasizes code readability and simplicity, and is suitable for scientific computing, data analysis and other fields.

What to do if the git download is not active What to do if the git download is not active Apr 17, 2025 pm 04:54 PM

Resolve: When Git download speed is slow, you can take the following steps: Check the network connection and try to switch the connection method. Optimize Git configuration: Increase the POST buffer size (git config --global http.postBuffer 524288000), and reduce the low-speed limit (git config --global http.lowSpeedLimit 1000). Use a Git proxy (such as git-proxy or git-lfs-proxy). Try using a different Git client (such as Sourcetree or Github Desktop). Check for fire protection

How to adjust the wordpress article list How to adjust the wordpress article list Apr 20, 2025 am 10:48 AM

There are four ways to adjust the WordPress article list: use theme options, use plugins (such as Post Types Order, WP Post List, Boxy Stuff), use code (add settings in the functions.php file), or modify the WordPress database directly.

How to solve the efficient search problem in PHP projects? Typesense helps you achieve it! How to solve the efficient search problem in PHP projects? Typesense helps you achieve it! Apr 17, 2025 pm 08:15 PM

When developing an e-commerce website, I encountered a difficult problem: How to achieve efficient search functions in large amounts of product data? Traditional database searches are inefficient and have poor user experience. After some research, I discovered the search engine Typesense and solved this problem through its official PHP client typesense/typesense-php, which greatly improved the search performance.

Golang vs. Python: Performance and Scalability Golang vs. Python: Performance and Scalability Apr 19, 2025 am 12:18 AM

Golang is better than Python in terms of performance and scalability. 1) Golang's compilation-type characteristics and efficient concurrency model make it perform well in high concurrency scenarios. 2) Python, as an interpreted language, executes slowly, but can optimize performance through tools such as Cython.

Python vs. C  : Learning Curves and Ease of Use Python vs. C : Learning Curves and Ease of Use Apr 19, 2025 am 12:20 AM

Python is easier to learn and use, while C is more powerful but complex. 1. Python syntax is concise and suitable for beginners. Dynamic typing and automatic memory management make it easy to use, but may cause runtime errors. 2.C provides low-level control and advanced features, suitable for high-performance applications, but has a high learning threshold and requires manual memory and type safety management.

See all articles