温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

LeetCode如何替换所有问号

发布时间:2021-12-15 13:53:07 来源:亿速云 阅读:138 作者:小新 栏目:大数据

这篇文章将为大家详细讲解有关LeetCode如何替换所有问号,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

题目

给你一个仅包含小写英文字母和 '?' 字符的字符串 s,请你将所有的 '?' 转换为若干小写字母,使最终的字符串不包含任何 连续重复 的字符。

题目测试用例保证 除 '?' 字符 之外,不存在连续重复的字符。

在完成所有转换(可能无需转换)后返回最终的字符串。如果有多个解决方案,请返回其中任何一个。可以证明,在给定的约束条件下,答案总是存在的。

思路

因为前两天比赛有遇到字符串替换的题,看到这个,和同学讨论了下。

将字符串存放于数组中,遍历,判断其是否为'?'

若当前元素是第一个元素,且是唯一一个元素,那么将其直接替换为‘a',

若不唯一,将其替换为与后一位不同的小写字母;

若当前元素是最后一个元素,那么将其替换为与前一位不同的小写字母;

若当前元素处于字符串中间位置,那么将其替换为与前后均不相同的小写字母;

替换的过程:从'a'开始,判断newChar与其前/后字符是否相同,若相同,顺延。

代码
	public String modifyString(String s)  {
        if(s == " "){
            return "当前字符串为空,请正确输入!";
        }
		char [] c = s.toCharArray();
		for(int i = 0; i < s.length(); i++) {
			if(c[i] == '?') {
				char newChar = 'a';
				while ((i>0 && c[i-1]==newChar) || (i<s.length()-1 && c[i+1]==newChar)) {
					newChar++;
				}
				c[i] = newChar;
			}
			
		}
		return String.valueOf(c);
	}
demo
输入:s = "?zs"
输出:"azs"
输入:s = "??yw?ipkj?"
输出:"acywaipkja"
运行结果

LeetCode如何替换所有问号

LeetCode如何替换所有问号

其他解答中的技巧

首尾特殊

可以在字符串首位加空格,这样每次遇到'?',就可以直接将其替换成与前后不同的小写字母,免除了第一个、最后一个、长度为1的特殊判断,;输出start+1至end-1。

简化修改

newChar只要与相邻俩元素不一样即可,可以取任意三个如'a','b','c'作为备选。

关于“LeetCode如何替换所有问号”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI