密码输入检测 - 华为OD统一考试

OD统一考试(C卷)

分值: 100分

题解: Java / Python / C++

alt

题目描述

给定用户密码输入流input,输入流中字符 ‘<’ 表示退格,可以清除前一个输入的字符,请你编写程序,输出最终得到的密码字符,并判断密码是否满足如下的密码安全要求。

密码安全要求如下:

  1. 密码长度>=8;
  2. 密码至少需要包含1个大写字母:
  3. 密码至少需要包含1个小写字母;
  4. 密码至少需要包含1个数字;
  5. 密码至少需要包含1个字母和数字以外的非空白特殊字符;

注意空串退格后仍然为空串,且用户输入的字符串不包含 ‘<’ 字符和空白字符。

输入描述

用一行字符串表示输入的用户数据,输入的字符串中 ‘<’ 字符标识退格,用户输入的字符串不包含空白字符,例如:ABC<c89%000<

输出描述

输出经过程序处理后,输出的实际密码字符串,并输出该密码字符串是否满足密码安全要求。两者间由 ‘,’ 分隔,例如:ABc89%00,true

示例1

输入:
ABC<c89%000<

输出:
ABc89%00,true

解释: 多余的C和0由于退格被去除,最终用户输入的密码为ABc89%00,且满足密码安全要求输出true

示例2

输入:
ABC

输出:
ABC,false

解释: 不满足密码安全要求

题解

字符串模拟题, 代码思路:

  1. 字符处理:使用Deque(双端队列)来处理字符输入和退格操作。遍历输入的字符数组,如果是退格字符'<',则从队尾删除一个字符;否则,将字符加入队尾。
  2. 密码安全要求判断:统计密码中包含的小写字母、大写字母、数字和其他字符的数量(c1c2c3c4)。判断密码是否满足安全要求:长度大于等于8,同时包含至少一个小写字母、一个大写字母、一个数字和一个其他字符。
  3. 输出结果:将密码字符串和判断结果以字符串格式输出,使用逗号分隔。

Java

import java.util.ArrayDeque;
import java.util.Deque;
import java.util.Scanner;
/**
 * @author code5bug
 */
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        String input = in.nextLine();
        Deque<Character> deque = new ArrayDeque<>();
        for (char c : input.toCharArray()) {
            if (Character.isWhitespace(c)) continue;

            // 退格,删除最后一个字符
            if (c == '<' && !deque.isEmpty()) {
                deque.pollLast();
            } else {
                deque.offerLast(c);
            }
        }

        StringBuilder password = new StringBuilder();
        // 记录各种类型字符的数量
        int c1 = 0, c2 = 0, c3 = 0, c4 = 0;
        while (!deque.isEmpty()) {
            char c = deque.pollFirst();
            password.append(c);
            if ('a' <= c && c <= 'z') {
                c1++;
            } else if ('A' <= c && c <= 'Z') {
                c2++;
            } else if ('0' <= c && c <= '9') {
                c3++;
            } else {
                c4++;
            }
        }

        boolean valid = password.length() >= 8 && c1 * c2 * c3 * c4 != 0;
        System.out.println(String.format("%s,%s", password.toString(), valid));
    }
}

Python

def process_password(input_str):
    # 使用列表模拟双端队列
    password_queue = []
    for char in input_str:
        if char.isspace():
            continue

        # 退格,删除最后一个字符
        if char == '<' and password_queue:
            password_queue.pop()
        else:
            password_queue.append(char)

    # 构建密码字符串
    password = ''.join(password_queue)

    # 统计各种类型字符的数量
    c1, c2, c3, c4 = 0, 0, 0, 0
    for char in password_queue:
        if 'a' <= char <= 'z':
            c1 += 1
        elif 'A' <= char <= 'Z':
            c2 += 1
        elif '0' <= char <= '9':
            c3 += 1
        else:
            c4 += 1

    # 判断密码是否满足安全要求
    valid = len(password) >= 8 and c1 * c2 * c3 * c4 != 0

    # 输出结果
    print(f"{password},{str(valid).lower()}")


# 从标准输入读取一行字符串
input_str = input()
# 处理密码
process_password(input_str)

C++

#include <iostream>
#include <deque>

using namespace std;

int main() {
    string input;
    getline(cin, input);

    deque<char> dq;
    for (char c : input) {
        if (isspace(c)) continue;

        // 退格,删除最后一个字符
        if (c == '<' && !dq.empty()) {
            dq.pop_back();
        } else {
            dq.push_back(c);
        }
    }

    string password;
    // 记录各种类型字符的数量
    int c1 = 0, c2 = 0, c3 = 0, c4 = 0;
    while (!dq.empty()) {
        char c = dq.front();
        dq.pop_front();
        password.push_back(c);
        if ('a' <= c && c <= 'z') {
            c1++;
        } else if ('A' <= c && c <= 'Z') {
            c2++;
        } else if ('0' <= c && c <= '9') {
            c3++;
        } else {
            c4++;
        }
    }

    bool valid = password.length() >= 8 && c1 * c2 * c3 * c4 != 0;
    cout << password << "," << (valid ? "true" : "false") << endl;

    return 0;
}

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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

fpmarkets盘点成功交易者的十个习惯(一)

在交易中能够盈利一次&#xff0c;fpmarkets认为这种情况100%的交易者都会做到&#xff0c;但是要做到每次交易都能盈利&#xff0c;即使是巴菲特也做到&#xff0c;我们只需要做到整体盈利就可以了&#xff0c;那么如何做到呢&#xff1f;今天fpmarkets就总结一下成功交易者的…

代码随想录算法训练营Day08|344.反转字符串、541. 反转字符串II、卡码网:替换数字、151.翻转字符串里的单词、卡码网:右旋字符串

文章目录 一、344.反转字符串1. 双指针法 二、541. 反转字符串II1. 字符串解法 三、卡码网&#xff1a;替换数字四、151.翻转字符串里的单词1.使用库函数2.自行编写函数3.创建字符数组填充3.双反转移位 五、卡码网&#xff1a;右旋字符串1. 自行编写函数 总结 一、344.反转字符…

【软件测试】白盒测试 / 逻辑覆盖法

《语句覆盖法》 使程序中的每个可执行语句至少执行一次 所有的可执行语句得到执行语句覆盖测试是较弱的一种测试发现错误能力最弱的逻辑覆盖 《判定覆盖法》 使每一个判定获得每一种可能的结果至少一次 每个判定得到真值和假值判断覆盖法满足了语句覆盖&#xff0c;因此比语…

【AI视野·今日Sound 声学论文速览 第四十期】Wed, 3 Jan 2024

AI视野今日CS.Sound 声学论文速览 Wed, 3 Jan 2024 Totally 4 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Sound Papers Auffusion: Leveraging the Power of Diffusion and Large Language Models for Text-to-Audio Generation Authors Jinlong Xue, Yayue De…

十一、工具盒类(MyQQ)(Qt5 GUI系列)

目录 ​编辑 一、设计需求 二、实现代码 三、代码解析 四、总结 一、设计需求 抽屉效果是软件界面设计中的一种常用形式&#xff0c;可以以一种动态直观的方式在有限大小的界面上扩展出更多的功能。本例要求实现类似 QQ 抽屉效果。 二、实现代码 #include "dialog.…

2024年第二届语言、创新教育与文化交流国际学术会议(CLEC 2024)

2024年第二届语言、创新教育与文化交流国际学术会议(CLEC 2024) 2024 2nd International Conference on Language, Innovative Education and Cultural Communication 为迎接知识经济时代的挑战&#xff0c;创新教育被用来培养学生的创新精神与能力。知识的普遍性使得创新教育…

CSS同时使用背景图和渐变色

CSS同时使用背景图和渐变色 需求代码实现完整写法 需求 一个盒子&#xff0c;在拥有渐变色的前提下还需要同时拥有背景图层 类似如下的效果 代码实现 首先我们按照常规的写css的方式来写 <div class"box"></div>.box{width: 300px;height: 120px;bo…

「网络安全术语解读」SARIF详解

引言&#xff1a;什么是SARIF&#xff1f;它的产生背景是什么&#xff1f;SARIF主要包含哪些内容&#xff1f;使用SARIF有哪些好处&#xff1f; 1. SARIF简介 SARIF&#xff08;Static Analysis Results Interchange Format &#xff0c;静态分析结果交换格式&#xff09;是一…

jenkins 自由风格部署vue项目,参数化构建vue项目

1. 丢弃旧的构建 2. 是否需要install 3. git 4. 配置node16: 5. 脚本&#xff1a; 脚本&#xff1a; #进入Jenkins工作空间下项目目录 cd /var/lib/jenkins/workspace/你的任务名称 node -v #检测node版本&#xff08;此条命令非必要&#xff09; npm -v #检测npm版本&#x…

电力系统中的交流负载箱

交流负载箱是电力系统中的一种重要设备&#xff0c;主要用于模拟实际的电力负载&#xff0c;以便对电力系统进行各种性能测试和分析。在电力系统的设计和运行过程中&#xff0c;交流负载箱起着至关重要的作用。 交流负载箱的主要功能是模拟实际的电力负载&#xff0c;包括电阻、…

开源内容管理框架Drupal在Docker本地部署并实现公网远程访问

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

2024--Django平台开发-Django知识点(四)

1.知识回顾 创建项目&#xff1a;新项目、别人项目、新版版、老版本 项目目录&#xff08;v1.0版本&#xff09; 路由系统 常见路由编写加粗样式 /index/ 函数 /index/<str:v1> 函数 re_path(ryy/(\d{4})-(\d{2})-(\d{2})/, views.yy), re_path(ryy/(?…

python炒股自动化(0),申请券商API接口

上次发了量化交易接口的区别&#xff0c;发现很多人根本不知道券商提供的API交易接口&#xff0c;这里补充一篇&#xff0c;关于券商接口的介绍。 现在市面上可以给个人账户接入的股票交易接口&#xff0c;用的最多的也就是QMT和Ptrade&#xff0c;以前接入量化交易需要机构或…

Mac上修复Gitee报错 Oauth: Access token is expired

一. 背景&#xff1a; 最近在gitee上拉了两次项目&#xff0c;两次使用的邮箱密码不一致&#xff08;换绑邮箱&#xff09;&#xff0c;第一次在idea中拉取后端项目&#xff0c;第二次在webstorm中拉取前端项目&#xff0c;出现该异常&#xff0c;记录下解决方案 二. 错误回显…

nodejs版本管理工具nvm的安装与使用

提示&#xff1a;nodejs版本管理工具nvm的安装与使用 文章目录 前言一、安装二、淘宝镜像配置三、安装所需版本的nodejs四、切换nodejs版本五、参考文档总结 前言 需求&#xff1a;新建一个vue3项目&#xff0c;&#xff0c;提示写法错误 查原因为node版本过低 随着技术更新迭…

24年初级会计报名注意事项及报名详细流程,快查收,错过再等一年

&#x1f369;初级会计报名正在进行中&#xff0c;报考的政策咱们了解了&#xff0c;那么报考流程&#xff0c;大家也先熟悉一下&#xff0c;&#x1f9c1;咱们报名就不会手忙脚乱咯&#x1f942; &#x1f9ca;具体有以下几步&#xff1a;#新手帮扶计划# 1️⃣登录全国资格评…

误删除的备忘录恢复方法是什么?备忘录不小心删除了怎么找回?

有不少小伙伴在使用手机的过程中&#xff0c;想要随手记录一些琐事或容易忘记的事情&#xff0c;使用手机系统备忘录或便签等记事工具是非常便捷的。不过在日积月累的使用过程中&#xff0c;备忘录中记录的内容就会越来越多&#xff0c;为了高效使用它&#xff0c;就需要定期删…

如何快速制作网址的静态码?网址二维码在线制作的简单技巧

现在很多人会将网址转换成静态二维码来使用&#xff0c;一个原因是扫码更符合现在人们的生活习惯&#xff0c;二来是采用二维码图片来做传播能够有效的节省制作者的成本&#xff0c;而且容易更快的完成网址内容的传播&#xff0c;所以将网址生成二维码的方法现在应用非常的广泛…

啊哈c语言——5.9逻辑挑战11(猜数游戏)

计算机会随机地给出0&#xff5e;99之间的一个整数&#xff0c;你能否猜出这个数呢&#xff1f;每猜一次&#xff0c;计算机都会告诉你猜的数是大了还是小了&#xff0c;直到你猜出这个数为止。 首先我们需要解决的第一个问题就是如何让计算机随机地产生一个整数&#xff0c;这…

Oracle11.2.0.4从RMAN备份中快速恢复单个表的方法

文章目录 前言一、查询所要恢复的表所涉及的表空间二、创建用于恢复的数据库三、恢复步骤1.恢复控制文件2.修改redo日志名称3.表空间恢复4.表空间recover5.查询数据 前言 由于用户误操作导致某表中的数据错乱&#xff0c;导致业务不能正常使用&#xff0c;现需要将该表恢复到一…