字符串拼接 - 华为OD统一考试(C卷)

OD统一考试(C卷)

分值: 200分

题解: Java / Python / C++

alt

题目描述

给定 M 个字符( a-z ) ,从中取出任意字符(每个字符只能用一次)拼接成长度为 N 的字符串,要求相同的字符不能相邻。

计算出给定的字符列表能拼接出多少种满足条件的字符串,输入非法或者无法拼接出满足条件的字符串则返回 0 。

输入描述

给定长度为 M 的字符列表和结果字符串的长度 N ,中间使用空格(" ")拼接。

  • 0 < M < 30
  • 0 < N ≤ 5

输出描述

输出满足条件的字符串个数。

示例1

输入:
abc 1输出:
3说明:
给定的字符为 abc ,结果字符申长度为 1 ,可以拼接成 a、b、c ,共 3 种。

示例2

输入:
dde 2输出:
2说明:
给定的字符为 dde ,果字符串长度为 2 ,可以拼接成 de、ed, 共 2 种。

题解

这个问题是通过回溯法(Backtracking)解决。

回溯法是一种深度优先搜索的算法,它尝试在解空间中逐步构建解,并在发现当前解不符合条件时进行回溯。

对于这个问题,可以考虑从第一个位置开始选择字符,然后在每个位置上选择不同的字符,直到构建出长度为 N 的字符串,同时要满足相邻字符不相同的条件。

具体步骤
  1. 定义一个递归函数 solve,参数包括前一个字符 pre 和剩余字符个数 todo
  2. solve 函数中,对于当前位置的每个字符,如果该字符与前一个字符相同,跳过;
  3. 否则,选择该字符,将字符数量减一,递归到下一个位置,并将结果加到总数中,然后恢复字符数量。
  4. main 函数中,读取输入,检查是否存在非法字符,然后调用 solve 函数计算满足条件的字符串个数。
代码描述

cnt 是一个数组,用于记录每个字符在给定字符串中的出现次数。

在这个问题中,cnt 数组的长度是 26,对应着英文字母表中的 26 个小写字母。数组中的每个元素表示对应字母的出现次数。

在代码中,首先通过遍历输入字符串,统计每个字符的出现次数,然后根据这个数组进行递归计算满足条件的字符串个数。

cnt 的目的是为了方便在递归过程中追踪每个字符的剩余数量,以确保相同的字符不能相邻出现。

在递归的过程中,每次选择一个字符,都会将对应位置的 cnt 减 1,递归完成后再将其加 1,以确保不影响后续的递归分支。

Java

import java.util.Scanner;/*** @author code5bug*/
public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);String input = in.next();int n = in.nextInt();// 是否非法输入boolean illegal = false;// 每个字符的个数int[] cnt = new int[26];for (char c : input.toCharArray()) {int idx = c - 'a';if (0 <= idx && idx < 26) {cnt[idx]++;} else {illegal = true;}}if (illegal) {System.out.println(0);} else {System.out.println(solve(cnt, -1, n));}}/*** @param cnt  字符个数统计* @param pre  前一个字符的下标* @param todo 剩余的字符个数* @return 组合数量*/static int solve(int[] cnt, int pre, int todo) {// 组合成功if (todo == 0) return 1;int tot = 0;for (int i = 0; i < 26; i++) {// 前一个字符和当前字符相同或者没有字符了,跳过if (cnt[i] == 0 || i == pre) continue;// 选择当前字符,剩余字符数-1,递归求解求和,恢复字符数量cnt[i]--;tot += solve(cnt, i, todo - 1);cnt[i]++;}return tot;}
}

Python

def solve(pre: int, todo: int) -> int:""":param pre: 前一个字符的下标:param todo: 剩余的字符个数:return: 组合数量"""global cntif todo == 0:return 1tot = 0for i in range(26):if cnt[i] == 0 or i == pre:  # 前一个字符和当前字符相同或者没有字符了,跳过continue# 选择当前字符,剩余字符数-1,递归求解求和,恢复字符数量cnt[i] -= 1tot += solve(i, todo - 1)cnt[i] += 1return totif __name__ == "__main__":s, n = input().split()n = int(n)illegal = False# 每个字符的个数cnt = [0] * 26for c in s:idx = ord(c) - ord('a')if 0 <= idx < 26:cnt[idx] += 1else:illegal = Trueif illegal:print(0)else:print(solve(-1, n))

C++

#include <iostream>using namespace std;int cnt[26]; // 全局变量,每个字符的个数int solve(int pre, int todo) {if (todo == 0) {return 1;}int tot = 0;for (int i = 0; i < 26; ++i) {if (cnt[i] == 0 || i == pre) { // 前一个字符和当前字符相同或者没有字符了,跳过continue;}// 选择当前字符,剩余字符数-1,递归求解求和,恢复字符数量cnt[i]--;tot += solve(i, todo - 1);cnt[i]++;}return tot;
}int main() {string s;int n;cin >> s >> n;bool illegal = false;// 每个字符串的个数for (char c : s) {int idx = c - 'a';if (0 <= idx && idx < 26) {cnt[idx]++;} else {illegal = true;}}if (illegal) {cout << 0 << endl;} else {cout << solve(-1, n) << endl;}return 0;
}

相关练习题

题号题目难易
LeetCode LCR 083LCR 083. 全排列中等
LeetCodeLCR 084LCR 084. 全排列 II 中等
LeetCode 4646. 全排列中等

‍❤️‍华为OD机试面试交流群(每日真题分享): 加V时备注“华为od加群”

🙏整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/258397.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Maui blazor ios 按设备类型设置是否启用safeArea

需求&#xff0c;新做了个app&#xff0c; 使用的是maui blazor技术&#xff0c;里面用了渐变背景&#xff0c;在默认启用SafeArea情况下&#xff0c;底部背景很突兀 由于现版本maui在SafeArea有点bug&#xff0c;官方教程的<ContentPage SafeAreafalse不生效&#xff0c;于…

【机器学习】数据清洗之识别重复点

&#x1f388;个人主页&#xff1a;甜美的江 &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f917;收录专栏&#xff1a;机器学习 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共同学习、交流进步…

STM32 HAL库 STM32CubeMX -- IWDG(独立看门狗)

STM32 HAL库 STM32CubeMX -- IWDG 一、IWDG简介二、独立看门狗的工作原理三、驱动函数初始化函数HAL IWDG Init()初始化函数HAL IWDG Init()其他宏函数 四、超时时间计算第一种办法第二种办法&#xff08;推荐&#xff09; 一、IWDG简介 看门狗(Watchdog)就是MCU上的一种特殊的…

SORA:OpenAI最新文本驱动视频生成大模型技术报告解读

Video generation models as world simulators&#xff1a;作为世界模拟器的视频生成模型 1、概览2、Turning visual data into patches&#xff1a;将视觉数据转换为补丁3、Video compression network&#xff1a;视频压缩网络4、Spacetime Latent Patches&#xff1a;时空潜在…

SAP PP学习笔记- 豆知识02 - 品目要谁来维护?怎么决定更不更新品目的数量金额?

其实都是在品目类型的Customize中设定的。 咱们这里简单试着说一下什么场景使用。 1&#xff0c;SAP中品目有很多View&#xff0c;都要由哪些部门来维护呢&#xff1f; 其实就是谁用谁维护呗。 在新建一个品目的时候&#xff0c;品目Type本身就决定了该品目要由哪些部门来维…

【STM32 CubeMX】串口编程DMA

文章目录 前言一、DMA方式1.1 DMA是什么1.2 CubeMX配置DMA1.3 DMA方式函数使用DMA的发送接收函数 总结 前言 在嵌入式系统中&#xff0c;串口通信是一项至关重要的功能&#xff0c;它允许单片机与外部设备进行数据交换&#xff0c;如传感器、显示器或其他设备。然而&#xff0…

【数据结构】16 二叉树的定义,性质,存储结构(以及先序、后序、中序遍历)

二叉树 一个二叉树是一个有穷的结点集合。 它是由根节点和称为其左子树和右子树的两个不相交的二叉树组成的。 二叉树可具有以下5种形态。 性质 一个二叉树第i层的最大结点数为 2 i − 1 2^{i-1} 2i−1, i ≥ 1 i \geq 1 i≥1 每层最大结点可以对应完美二叉树&#xff08;…

阿里云服务器租用收费标准价格表(2024年更新)

2024年最新阿里云服务器租用费用优惠价格表&#xff0c;轻量2核2G3M带宽轻量服务器一年61元&#xff0c;折合5元1个月&#xff0c;新老用户同享99元一年服务器&#xff0c;2核4G5M服务器ECS优惠价199元一年&#xff0c;2核4G4M轻量服务器165元一年&#xff0c;2核4G服务器30元3…

Gitee入门之工具的安装

一、gitee是什么&#xff1f; Gitee&#xff08;码云&#xff09;是由开源中国社区在2013年推出的一个基于Git的代码托管平台&#xff0c;它提供中国本土化的代码托管服务。它旨在为个人、团队和企业提供稳定、高效、安全的云端软件开发协作平台&#xff0c;具备代码质量分析、…

React18原理: 核心包结构与两大工作循环

React核心包结构 1 ) react react基础包&#xff0c;只提供定义 react组件(ReactElement)的必要函数一般来说需要和渲染器(react-dom,react-native)一同使用在编写react应用的代码时, 大部分都是调用此包的api比如, 我们定义组件的时候&#xff0c;就是它提供的class Demo ext…

springboot198基于springboot的智能家居系统

基于Springboot的智能家居系统 **[摘要]**社会和科技的不断进步带来更便利的生活&#xff0c;计算机技术也越来越平民化。二十一世纪是数据时代&#xff0c;各种信息经过统计分析都可以得到想要的结果&#xff0c;所以也可以更好的为人们工作、生活服务。智能家居是家庭的重要…

【排序算法】C语言排序(桶排序,冒泡排序,选择排序,插入排序,快速排序)

目录 什么是排序&#xff1f;1、桶排序 概念思路demo运行效果 2、冒泡排序 动图演示概念思路demo运行效果 3、选择排序 动图演示概念思路demo运行结果 4、插入排序 动图演示概念思路demo运行效果 5、快速排序 动图演示概念思路demo运行结果 什么是排序&#xff1f; 排序&…

“分布式透明化”在杭州银行核心系统上线之思考

导读 随着金融行业数字化转型的需求&#xff0c;银行核心系统的升级改造成为重要议题。杭州银行成功上线以 TiDB 为底层数据库的新一代核心业务系统&#xff0c;该实践采用应用与基础设施解耦、分布式透明化的设计开发理念&#xff0c;推动银行核心系统的整体升级。 本文聚焦…

easyx搭建项目-永七大作战(割草游戏)

永七大作战 游戏介绍&#xff1a; 永七大作战 游戏代码链接&#xff1a;永七大作战 提取码&#xff1a;ABCD 不想水文了&#xff0c;直接献出源码&#xff0c;表示我的诚意

Shellcode免杀对抗(Python)

Shellcode Python免杀&#xff0c;绕过360安全卫士、火绒安全、Defender Python基于cs/msf的上线 cs 执行代码2种可供选择 执行代码 1&#xff1a; rwxpage ctypes.windll.kernel32.VirtualAlloc(0, len(shellcode), 0x1000, 0x40) ctypes.windll.kernel32.RtlMoveMemory…

静态时序分析:SDC约束命令set_clock_transition详解

相关阅读 静态时序分析https://blog.csdn.net/weixin_45791458/category_12567571.html?spm1001.2014.3001.5482 在静态时序分析&#xff1a;SDC约束命令create_clock详解一文的最后&#xff0c;我们谈到了针对理想(ideal)时钟&#xff0c;可以使用set_clock_transition命令直…

【VSCode】使用笔记

目录 快捷键系列 相关插件 相关文档链接 快捷键系列 调出终端 ctrl 或者是ctrlJ 结束进程 ctrlc 注释 ctrlkc 取消注释 ctrlku 上下移动代码 alt方向键 多行光标ctrlalt方向键 快速跳过某个单词 ctrl方向键 相关插件 1.每次修改后&#xff0c;自动保存启动项目 相…

2.12:C语言测试题

1.段错误&#xff1a;申请堆区内存未返回&#xff0c;str指向NULL 2.段错误&#xff1a;局部变量&#xff0c;本函数结束&#xff0c;p也释放 3.越界访问&#xff0c;可能正常输出hello&#xff0c;可能报错 4.可能段错误&#xff0c;释放后&#xff0c;str未指向NULL&#x…

【旧文更新】【优秀毕设】人脸识别打卡/签到/考勤管理系统(OpenCV+最简基本库开发、可移植树莓派 扩展网络图像推流控制 验证码及Excel邮件发送等功能)

【旧文更新】【优秀毕设】人脸识别打卡/签到/考勤管理系统&#xff08;OpenCV最简基本库开发、可移植树莓派 扩展网络图像推流控制 验证码及Excel邮件发送等功能&#xff09; 文章目录 关于旧文新发毕设结构主页面验证码识别效果管理页面人脸信息采集管理实时数据更新签到结果…

CSS 不同颜色的小圆角方块组成的旋转加载动画

<template><!-- 创建一个装载自定义旋转加载动画的容器 --><view class="spinner"><!-- 定义外部包裹容器,用于实现整体旋转动画 --><view class="outer"><!-- 定义四个内部小方块以形成十字形结构 --><view clas…