当前位置: 首页 > article >正文

华为OD E卷(100分)31-敏感字段加密

前言

        工作了十几年,从普通的研发工程师一路成长为研发经理、研发总监。临近40岁,本想辞职后换一个相对稳定的工作环境一直干到老, 没想到离职后三个多月了还没找到工作,愁肠百结。为了让自己有点事情做,也算提高一下自己的编程能力,无聊之余打算用一些大厂的编程题练练手。希望通过这些分享能够帮到一些人,也希望能和看到此文的大神们沟通交流,提升自己,更希望在此期间能够找到一份理想的工作。

题目描述

        给定一个由多个命令字组成的命令字符串:

  1. 字符串长度小于等于127字节,只包含大小写字母,数字,下划线和偶数个双引号; 
  2. 命令字之间以一个或多个下划线 进行分割; 
  3. 可以通过两个双引号""来标识包含下划线 的命令字或空命令字(仅包含两个双引号的命令字),双引号不会在命令字内部出现;

        请对指定索引的敏感字段进行加密,替换为******(6个*),并删除命令字前后多余的下划线_。
如果无法找到指定索引的命令字,输出字符串ERROR.

输入

        输入为两行,第一行为命令字索引K(从0开始),第二行为命令字符串S。

输出

        输出处理后的命令字符串,如果无法找到指定索引的命令字,输出字符串ERROR。

示例

示例1

输入:
1
password__a12345678_timeout_100
输出:
password_******_timeout_100

示例2

输入:
2
aaa_password_"a12_45678"_timeout__100_""_
输出:

aaa_password_******_timeout_100_""

解题思路

遍历字符串:
        当遇到“_” ,且不在括号内时,为一个完整的指令;

        当遇到 “” 时,判断是否引用结束;

题解

JAVA实现

package huawei.e100;

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

/**
* @author arnold
* @date 2024年12月21日
* 敏感字段加密
*/
public class T31_MinGanZiDuanJiaMi {

	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		while(sc.hasNext()) {
			int index = sc.nextInt();
			sc.nextLine();
			String str = sc.nextLine();
			String res = run(str, index);
			System.out.println(res);
		}

	}
	
	static String run(String str, int index) {
		List<String> lcmds = new ArrayList<String>();
		boolean isInQuote = false;
		int start = 0; // 记录指令开始位置
		for (int i = 1; i < str.length(); i++) {
			if (str.charAt(i) == '"') {
				isInQuote = !isInQuote;
			}
			if(str.charAt(i) == '_' ){
				if (str.charAt(i-1) != '_' && !isInQuote) {
					lcmds.add(str.substring(start, i));
				}
			} else if(str.charAt(i) != '_' ) {
				if (str.charAt(i-1) == '_' && !isInQuote) {
					start = i;
				} else if (i == str.length() -1) { 
					lcmds.add(str.substring(start)); // 最后命令部分 从起始截取到最后
				}
			}
		}
		if (index < lcmds.size()) {
			lcmds.set(index, "******");
			return String.join("_", lcmds);
		} else {
			return "ERROR";
		}
	}

}

http://www.kler.cn/a/452946.html

相关文章:

  • MyBatis的插件运行原理,与如何编写一个插件
  • 华为管理变革之道:奋斗文化与活力
  • 【GeekBand】C++设计模式笔记15_Proxy_代理模式
  • 图解HTTP-HTTP状态码
  • 【ES6复习笔记】Symbol 类型及其应用(9)
  • Flink调优----反压处理
  • github如何给本机绑定 ssh密钥(MACOS)
  • React图标库: 使用React Icons实现定制化图标效果
  • 利用Java爬虫获取速卖通(AliExpress)商品详情的详细指南
  • Xshell 和 Xftp 更新提示问题的解决方法及分析
  • 【机器学习】机器学习的基本分类-半监督学习(Semi-supervised Learning)
  • Go语言gRPC与gozero的api
  • 如何选择最佳时间进行WordPress网站维护避免流量损失
  • 轻量级安全云存储方案Hoodik
  • 分布式协同 - 分布式事务_2PC 3PC解决方案
  • 【Java基础面试题044】使用new String(“哈哈“)语句会创建几个对象?
  • C++-------动态内存管理
  • LDR6020在iPad一体式键盘的创新应用
  • Spring提供了很好事务管理机制
  • Mac提示:安装anycast后台服务进程失败
  • STM32之GPIO输出与输出
  • Vivado常用IP例化2
  • 新能源汽车双向峰谷充放电研究
  • 查看mysql编译参数
  • IT运维中的自然语言处理(NLP)技术应用
  • php8.0版本更新了哪些内容