LeetCode如何替换所有问号

这篇文章将为大家详细讲解有关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
demo
输入:s = "?zs"
输出:"azs"
输入:s = "??yw?ipkj?"
输出:"acywaipkja"
运行结果

LeetCode如何替换所有问号

LeetCode如何替换所有问号

其他解答中的技巧

首尾特殊

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

简化修改

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

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


当前标题:LeetCode如何替换所有问号
本文来源:http://scyanting.com/article/posjsi.html