这篇文章将为大家详细讲解有关LeetCode如何替换所有问号,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。题目给你一个仅包含小写英文字母和 '?' 字符的字符串 s,请你将所有的 '
这篇文章将为大家详细讲解有关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);}
输入:s = "?zs"输出:"azs"
输入:s = "??yw?ipkj?"输出:"acywaipkja"
首尾特殊
可以在字符串首位加空格,这样每次遇到'?'
,就可以直接将其替换成与前后不同的小写字母,免除了第一个、最后一个、长度为1的特殊判断,;输出start+1至end-1。
简化修改
newChar只要与相邻俩元素不一样即可,可以取任意三个如'a','b','c'
作为备选。
关于“LeetCode如何替换所有问号”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
--结束END--
本文标题: LeetCode如何替换所有问号
本文链接: https://lsjlt.com/news/295731.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
2024-05-24
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0