华为OD机试真题——单词接龙(首字母接龙)(2025A卷:100分)Java/python/JavaScript/C/C++/GO最佳实现

news2025/5/15 14:45:23

在这里插入图片描述

2025 A卷 100分 题型

本专栏内全部题目均提供Java、python、JavaScript、C、C++、GO六种语言的最佳实现方式;
并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析;
本文收录于专栏:《2025华为OD真题目录+全流程解析+备考攻略+经验分享》

华为OD机试真题《单词接龙(首字母接龙)》:


文章快捷目录

题目描述及说明

Java

python

JavaScript

C++

C

GO

更多内容


题目名称:单词接龙(首字母接龙)


知识点:字符串、贪心算法、逻辑处理
时间限制:1秒
空间限制:256MB
限定语言:不限


题目描述

给定一组由小写字母组成的单词数组,并指定其中一个单词作为起始单词,按照以下规则进行单词接龙,输出最长的拼接字符串(无空格):

  1. 接龙规则:每个后续单词的首字母必须与前一个单词的尾字母相同。
  2. 选择优先级:当存在多个可选单词时,优先选择长度最长的;若长度相同,则选择字典序最小的。
  3. 去重规则:已使用的单词不可重复使用。

输入描述

  • 第一行为起始单词的索引 K(0 ≤ K < N)。
  • 第二行为单词总数 N(1 ≤ N ≤ 20)。
  • 后续 N 行,每行一个单词(长度1~30)。

输出描述
拼接后的最长单词串。

示例
输入:

0  
6  
word  
dd  
da  
dc  
dword  
d  

输出:

worddwordda  

解释:起始单词 word → 接 dword(最长且首字母为 d)→ 剩余可选 dddadc,选择字典序最小的 da


Java

问题分析

题目要求根据给定的单词列表,从指定起始单词开始,按照首尾字母相同的规则进行接龙,选择时优先选最长的单词,长度相同则选字典序最小的,且每个单词只能用一次。目标是找到最长的拼接字符串。


解题思路

  1. 深度优先搜索(DFS):遍历所有可能的路径,记录最长拼接字符串。
  2. 贪心剪枝:在每一步中按优先级处理候选单词(长度优先,字典序次之),尝试快速找到最优解。
  3. 回溯:标记已使用的单词,递归结束后恢复状态,确保其他路径可被探索。

代码实现

import java.util.*;

public class Main {
   
    private static String maxStr = ""; // 存储最长结果
    private static int maxLen = 0;     // 最长字符串长度
    private static int totalLen = 0;    // 所有单词总长度(用于剪枝)

    public static void main(String[] args) {
   
        Scanner sc = new Scanner(System.in);
        int k = Integer.parseInt(sc.nextLine()); // 起始单词索引
        int n = Integer.parseInt(sc.nextLine()); // 单词总数
        String[] words = new String[n];
        for (int i = 0; i < n; i++) {
   
            words[i] = sc.nextLine().trim();
        }

        // 计算所有单词总长度
        for (String word : words) {
   
            totalLen += word.length();
        }

        boolean[] used = new boolean[n]; // 记录单词是否被使用
        String startWord = words[k];
        used[k] = true;
        maxStr = startWord;
        maxLen = startWord.length();

        dfs(startWord, startWord.charAt(startWord.length() - 1), used, words, startWord.length());
        System.out.println(maxStr);
    }

    private static void dfs(String currentStr, char lastChar, boolean[] used, String[] words, int usedLen) {
   
        // 更新最长结果
        int currentLen = currentStr.length();
        if (currentLen > maxLen || (currentLen == maxLen && currentStr.compareTo(maxStr) < 0)) {
   
            maxStr = currentStr;
            maxLen = currentLen;
        }

        // 剪枝:当前长度 + 剩余单词总长度 <= 已找到的最大长度,无需继续
        int remaining = totalLen - usedLen;
        if (currentLen + remaining <= maxLen) {
   
            return;
        }

        // 收集所有可用的候选单词(首字母匹配且未被使用)
        List<Candidate> candidates = new ArrayList<>();
        for (int i = 0; i < words.length; i++) {
   
            if (!used[i] && words[i].charAt(0) == lastChar) {
   
                candidates.add(new Candidate(words[i], i));
            }
        }

        // 按长度降序、字典序升序排序
        Collections.sort(candidates, (a, b) -> {
   
            if (a.word.length() != b.word.length()) {
   
                return Integer.compare(b.word.length(), a.word.length());
            } else {
   
                return a.word.compareTo(b.word);
            }
        });

        // 递归处理每个候选
        for (Candidate c : candidates) {
   
            String word = c.word;
            int idx = c.index;
            used[idx] = true; // 标记为已用
            dfs(currentStr + word, word.charAt(word.length() - 1), used, words, usedLen + word.length());
            used[idx] = false; // 回溯
        }
    }

    // 辅助类,记录单词及其索引
    static class Candidate {
   
        String word;
        int index;

        Candidate(String word, int index) {
   
            this.word = word;
            this.index = index;
        }
    }
}

代码解析

  1. 全局变量

    • maxStr:记录当前最长的拼接字符串。
    • maxLen:记录最长字符串的长度。
    • totalLen:所有单词的总长度,用于剪枝。
  2. 输入处理

    • 读取起始索引 k 和单词列表,初始化 used 数组标记起始单词为已使用。
  3. DFS函数

    • 更新最长字符串:比较当前拼接长度,更新 maxStrmaxLen
    • 剪枝:若当前长度加上剩余单词总长度无法超过已知最长长度,提前返回。
    • 候选单词收集:筛选所有首字母匹配且未被使用的单词。
    • 排序:按长度降序和字典序升序排列候选单词。
    • 递归处理:依次选择每个候选单词,标记为已用,递归调用后回溯。
  4. Candidate类

    • 记录单词及其索引,方便排序后回溯时恢复状态。<

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

计算机网络-MPLS VPN基础概念

前面几篇文章我们学习了MPLS的标签转发原理&#xff0c;有静态标签分发和LDP动态标签协议&#xff0c;可以实现LSR设备基于标签实现数据高效转发。现在开始学习MPLS在企业实际应用的场景-MPLS VPN。 一、MPLS VPN概念 MPLS&#xff08;多协议标签交换&#xff09;位于TCP/IP协…

【Linux系列】bash_profile 与 zshrc 的编辑与加载

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

Spring Boot中的拦截器!

每次用户请求到达Spring Boot服务端&#xff0c;你是否需要重复写日志、权限检查或请求格式化代码&#xff1f;这些繁琐的“前置后置”工作让人头疼&#xff01;好在&#xff0c;Spring Boot拦截器如同一道智能关卡&#xff0c;统一处理请求的横切逻辑&#xff0c;让代码优雅又…

基于 Spring Boot 瑞吉外卖系统开发(十五)

基于 Spring Boot 瑞吉外卖系统开发&#xff08;十五&#xff09; 前台用户登录 在登录页面输入验证码&#xff0c;单击“登录”按钮&#xff0c;页面会携带输入的手机号和验证码向“/user/login”发起请求。 定义UserMapper接口 Mapper public interface UserMapper exte…

计算机网络笔记(二十三)——4.5IPv6

4.5.1IPv6的基本首部 IPv6 的基本首部相对于 IPv4 进行了重大简化和优化&#xff0c;固定长度为 40 字节&#xff0c;大幅提升了路由器的处理效率。以下是各字段的详细说明&#xff1a; IPv6 基本首部字段组成 字段名位数作用描述版本 (Version)4 bits固定值为 6&#xff0c…

推荐一个Winform开源的UI工具包

从零学习构建一个完整的系统 推荐一个开源、免费的适合.NET WinForms 控件的套件。 项目简介 Krypton是一套开源的.Net组件&#xff0c;用于快速构建具有丰富UI交互的WinForms应用程序。 丰富的UI控件&#xff0c;提供了48个基础控件&#xff0c;如按钮、文本框、标签、下拉…

位与运算

只有当除数是 2 的幂次方&#xff08;如 2、4、8、16...&#xff09;时&#xff0c;取模运算才可以转换为位运算。 int b 19;int a1 b % 16; // 传统取模运算int a2 b & 15; // 位运算替代取模printf("b %d\n", b);printf("b %% 8 %d\n",…

趣味编程:四叶草

概述&#xff1a;在万千三叶草中寻觅&#xff0c;只为那一抹独特的四叶草之绿&#xff0c;它象征着幸运与希望。本篇博客主要介绍四叶草的绘制。 1. 效果展示 绘制四叶草的过程是一个动态的过程&#xff0c;因此博客中所展示的为绘制完成的四叶草。 2. 源码展示 #define _CR…

城市生命线综合管控系统解决方案-守护城市生命线安全

一、政策背景 国务院办公厅《城市安全风险综合监测预警平台建设指南》‌要求&#xff1a;将燃气、供水、排水、桥梁、热力、综合管廊等纳入城市生命线监测体系&#xff0c;建立"能监测、会预警、快处置"的智慧化防控机制。住建部‌《"十四五"全国城市基础…

# 2-STM32F103-复位和时钟控制RCC

STM32-复位和时钟控制RCC 2-STM32-复位和时钟控制RCC摘要说明本文参考资料如下&#xff1a; 一、STM32最小系统回顾STM32F103C8T6核心板原理图 二、复位三、时钟3.1 时钟树3.2 STM32启动过程3.2 SystemInit()函数3.2.1 SystemInit()第1句&#xff1a;3.2.2 SystemInit()第2句&a…

多模态大语言模型arxiv论文略读(七十五)

PosterLLaVa: Constructing a Unified Multi-modal Layout Generator with LLM ➡️ 论文标题&#xff1a;PosterLLaVa: Constructing a Unified Multi-modal Layout Generator with LLM ➡️ 论文作者&#xff1a;Tao Yang, Yingmin Luo, Zhongang Qi, Yang Wu, Ying Shan, C…

使用frp实现客户端开机自启(含静默运行脚本)

本文整理了如何使用 frp 客户端并实现 Windows 系统下的开机静默自启&#xff0c;适合远程桌面、内网穿透等场景。 &#x1f4c1; 目录结构 我将 frp 客户端文件放置在以下路径&#xff1a; F:\git\frp>tree /f 卷 其它 的文件夹 PATH 列表 卷序列号为 A123-0F4E F:. │ …

list 容器常见用法及实现

文章目录 1. list 的介绍与使用1.1 list 的介绍1.2 list 的使用1.2.1 list 的构造1.2.2 list iterator 的使用1.2.3 list capacity1.2.4 list element access1.2.5 list modifiers1.2.6 迭代器失效问题 2. list 的模拟实现2.1 值得注意的点&#xff1a;2.2 std::initializer_li…

iOS视频编码详细步骤(视频编码器,基于 VideoToolbox,支持硬件编码 H264/H265)

iOS视频编码详细步骤流程 1. 视频采集阶段 视频采集所使用的代码和之前的相同&#xff0c;所以不再过多进行赘述 初始化配置&#xff1a; 通过VideoCaptureConfig设置分辨率1920x1080、帧率30fps、像素格式kCVPixelFormatType_420YpCbCr8BiPlanarFullRange设置摄像头位置&am…

浅析 Golang 内存管理

文章目录 浅析 Golang 内存管理栈&#xff08;Stack&#xff09;堆&#xff08;Heap&#xff09;堆 vs. 栈内存逃逸分析内存逃逸产生的原因避免内存逃逸的手段 内存泄露常见的内存泄露场景如何避免内存泄露&#xff1f;总结 浅析 Golang 内存管理 在 Golang 当中&#xff0c;堆…

C++ 并发编程(1)再学习,为什么子线程不调用join方法或者detach方法,程序会崩溃? 仿函数的线程启动问题?为什么线程参数默认传参方式是值拷贝?

本文的主要学习点&#xff0c;来自 这哥们的视频内容&#xff0c;感谢大神的无私奉献。你可以根据这哥们的视频内容学习&#xff0c;我这里只是将自己不明白的点&#xff0c;整理记录。 C 并发编程(1) 线程基础&#xff0c;为什么线程参数默认传参方式是值拷贝&#xff1f;_哔…

【Python 算法零基础 2.模拟 ④ 基于矩阵】

目录 基于矩阵 Ⅰ、 2120. 执行所有后缀指令 思路与算法 ① 初始化结果列表 ② 方向映射 ③ 遍历每个起始位置 ④ 记录结果 Ⅱ、1252. 奇数值单元格的数目 思路与算法 ① 初始化矩阵 ② 处理每个操作 ③ 统计奇数元素 Ⅲ、 832. 翻转图像 思路与算法 ① 水平翻转图像 ② 像素值…

【教程】Docker方式本地部署Overleaf

转载请注明出处&#xff1a;小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你&#xff0c;欢迎[点赞、收藏、关注]哦~ 目录 背景说明 下载仓库 初始化配置 修改监听IP和端口 自定义网站名称 修改数据存放位置 更换Docker源 更换Docker存储位置 启动Overleaf 创…

3337|3335. 字符串转换后的长度 I(||)

1.字符串转换后的长度 I 1.1题目 3335. 字符串转换后的长度 I - 力扣&#xff08;LeetCode&#xff09; 1.2解析 递推法解析 思路框架 我们可以通过定义状态变量来追踪每次转换后各字符的数量变化。具体地&#xff0c;定义状态函数 f(i,c) 表示经过 i 次转换后&#xff0…

PHP黑白胶卷底片图转彩图功能 V2025.05.15

关于底片转彩图 传统照片底片是摄影过程中生成的反色图像&#xff0c;为了欣赏照片&#xff0c;需要通过冲印过程将底片转化为正像。而随着数字技术的发展&#xff0c;我们现在可以使用数字工具不仅将底片转为正像&#xff0c;还可以添加色彩&#xff0c;重现照片原本的色彩效…