华为OD机试真题【真正的密码】

1、题目描述

【题目描述】

在一行中输入一个字符串数组,如果其中一个字符串的所有以索引0开头的子串在数组中都有,那么这个字符串就是潜在密码,

在所有潜在密码中最长的是真正的密码,如果有多个长度相同的真正的密码,那么取字典序最大的为唯一的真正的密码,求唯一的真正的密码。

【示例1】
输入

h he hel hell hello o ok n ni nin ninj ninja
输出

ninja

说明

按要求,hello、ok、ninja都是潜在密码。

检查长度,hello、ninja是真正的密码。

检查字典序,ninja是唯一真正密码。

【示例2】
输入

a b c d f
输出

f

说明

按要求,a b c d f 都是潜在密码。

检查长度,a b c d f 是真正的密码。

检查字典序,f是唯一真正密码。

2、解题思路

将输入的字符串存入数组;使用HashSet存储这些字符串,确保唯一性;

遍历输入的字符串数组,针对每一个字符串,从索引1开始,判断其所有以索引0开头的子串是否在HashSet中;如果所有子串都在HashSet中,说明当前字符串是潜在密码;

如果当前潜在密码长度大于真正的密码长度,更新真正的密码为当前潜在密码;

如果当前潜在密码长度等于真正的密码长度,但字典序大于真正的密码,更新真正的密码为当前潜在密码;

3、参考代码

java 复制代码
import java.util.HashSet;
import java.util.Scanner;
import java.util.Set;

public class 真正的密码 {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNext()) {
            String[] strings = in.nextLine().split(" ");

            Set<String> wordSet = new HashSet<>();
            for (String string : strings) {
                wordSet.add(string);
            }

            String realPwd = "";
            // 遍历输入的字符串数组
            for (String string : strings) {
                boolean isPwd = false;
                for (int i = 1; i < string.length(); i++) {
                    String subStr = string.substring(0, i);
                    if (!wordSet.contains(subStr)) {
                        isPwd = true;
                        break;
                    }
                }

                // 如果所有子串都在set里,说明当前字符是潜在密码
                if (isPwd) {
                    if (string.length() > realPwd.length()) {
                        realPwd = string;
                    }
                    if (string.length() == realPwd.length() && string.compareTo(realPwd) > 0) {
                        realPwd = string;
                    }
                }
            }
            System.out.println(realPwd);
        }
    }
}

4、相似题目

相关推荐
jgbazsh1 分钟前
Redis6.2.6下载和安装
java
于先生吖4 分钟前
JAVA 本地生活服务项目实战 家政 5.0 系统前后端分离部署
java·开发语言·生活
计算机安禾6 分钟前
【数据结构与算法】第5篇:线性表(一):顺序表(ArrayList)的实现与应用
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio
ghie90908 分钟前
C# WinForms 条形码生成器(含保存和打印预览功能)
开发语言·c#
霑潇雨9 分钟前
题解 | 深入分析各款产品年总销售额与竞品的年度对比
大数据·开发语言·数据库
2401_8649592810 分钟前
C++与Python混合编程实战
开发语言·c++·算法
左左右右左右摇晃11 分钟前
Java并发——锁的状态演变
java·开发语言·笔记
2501_9454248012 分钟前
C++与硬件交互编程
开发语言·c++·算法
2301_8184190112 分钟前
C++中的表达式模板
开发语言·c++·算法
Roselind_Yi13 分钟前
排查Visual C++堆损坏(HEAP CORRUPTION)错误:从报错到解决的完整复盘
java·开发语言·c++·spring·bug·学习方法·远程工作