这篇文章将为大家详细讲解有关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) || (idemo
输入:s = "?zs" 输出:"azs"输入:s = "??yw?ipkj?" 输出:"acywaipkja"运行结果
其他解答中的技巧
首尾特殊
可以在字符串首位加空格,这样每次遇到
'?'
,就可以直接将其替换成与前后不同的小写字母,免除了第一个、最后一个、长度为1的特殊判断,;输出start+1至end-1。简化修改
newChar只要与相邻俩元素不一样即可,可以取任意三个如
'a','b','c'
作为备选。关于“LeetCode如何替换所有问号”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
当前题目:LeetCode如何替换所有问号
本文地址:http://lswzjz.com/article/posjsi.html