【华为机试】2023年真题B卷(python)-考古问题

一、题目

题目描述:

考古问题,假设以前的石碑被打碎成了很多块,每块上面都有一个或若干个字符,请你写个程序来把之前石碑上文字可能的组合全部写出来,按升序进行排列。

二、输入输出

三、示例

示例1:

输入输出示例仅供调试,后台判题数据一般不包含示例

输入:

3

a b c

输出

abc

acb

bac

bca

cab

cba
示例2:

输入输出示例仅供调试,后台判题数据一般不包含示例

输入

3

a b a

输出

aab

aba

baa

四、要求

时间限制:C/C++ 1秒,其他语言 2秒

空间限制:C/C++262144K,其他语言524288K

64bit IO Format:%lld

五、解题思路

排列组合问题,简单的 DFS

六、参考代码

python 复制代码
# -*- coding: utf-8 -*-
'''
@File    :   2023-B-考古问题.py
@Time    :   2023/12/30 22:51:00
@Author  :   mgc 
@Version :   1.0
@Desc    :   None
'''

# import os
# import re
# import sys
# import copy
# import math
# import queue
# import functools
# from queue import Queue
# from collections import Counter, defaultdict

def permutations(prefix, remaining, result):
    """
    生成所有可能的排列组合

    Args:
        prefix (str): 当前生成的排列组合的前缀
        remaining (list): 剩余的字符列表
        result (list): 存储生成的排列组合的结果列表
    """
    for i in range(len(remaining)):
        str_i = prefix + remaining[i]
        remaining_i = remaining[:i] + remaining[i+1:]
        if not remaining_i:
            if str_i not in result:
                result.append(str_i)
        else:
            permutations(str_i, remaining_i, result)


result = []
num = int(input())  # 输入字符块数量
list_n = input().split(' ')  # 输入字符块列表
permutations('', list_n, result)  # 生成排列组合
result.sort()  # 对结果进行排序
for s in result:
    print(s)  # 输出结果
相关推荐
封奚泽优5 分钟前
使用Labelme进行图像标注
开发语言·python·labelme
Fanmeang8 分钟前
华为防火墙基础功能详解:构建网络安全的基石
运维·网络·安全·华为·防火墙·策略·安全域
檐下翻书17312 分钟前
智能医疗大模型在医生培训中的应用案例
python
一只鱼^_17 分钟前
力扣第 474 场周赛
数据结构·算法·leetcode·贪心算法·逻辑回归·深度优先·启发式算法
爱笑的眼睛1130 分钟前
深入解析ArkTS类型系统:构建安全高效的HarmonyOS应用
华为·harmonyos
叫我龙翔30 分钟前
【数据结构】从零开始认识图论 --- 单源/多源最短路算法
数据结构·算法·图论
码界筑梦坊44 分钟前
243-基于Django与VUE的笔记本电脑数据可视化分析系统
vue.js·python·信息可视化·数据分析·django·毕业设计·echarts
深圳佛手1 小时前
几种限流算法介绍和使用场景
网络·算法
蛋仔聊测试1 小时前
Playwright 中route 方法模拟测试数据(Mocking)详解
前端·python·测试
今天没有盐1 小时前
Pandas缺失值处理完全指南:从基础操作到高级技巧
python·pycharm·编程语言