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

个人外贸网站建设docker wordpress多个

个人外贸网站建设,docker wordpress多个,wordpress 图片相对路径,郑州建设网站制作公司题目描述 给定一个字符串,要求逐个翻转其中的每个单词。输入字符串可能在前后包含多余的空格,并且单词之间可能存在多个空格,但反转后的字符串不能包含多余空格,单词间应仅保留一个空格。 示例 输入: "the sky is blue&qu…

题目描述

给定一个字符串,要求逐个翻转其中的每个单词。输入字符串可能在前后包含多余的空格,并且单词之间可能存在多个空格,但反转后的字符串不能包含多余空格,单词间应仅保留一个空格。

示例

  • 输入: "the sky is blue",输出: "blue is sky the"
  • 输入: " hello world! ",输出: "world! hello"
  • 输入: "a good example",输出: "example good a"

解法一:不使用 Java 内置方法实现

class Solution {/*** 不使用Java内置方法实现* <p>* 1.去除首尾以及中间多余空格* 2.反转整个字符串* 3.反转各个单词*/public String reverseWords(String s) {// 1.去除首尾以及中间多余空格StringBuilder sb = removeSpace(s);// 2.反转整个字符串reverseString(sb, 0, sb.length() - 1);// 3.反转各个单词reverseEachWord(sb);return sb.toString();}private StringBuilder removeSpace(String s) {int start = 0;int end = s.length() - 1;while (s.charAt(start) == ' ') start++;while (s.charAt(end) == ' ') end--;StringBuilder sb = new StringBuilder();while (start <= end) {char c = s.charAt(start);if (c != ' ' || sb.charAt(sb.length() - 1) != ' ') {sb.append(c);}start++;}return sb;}/*** 反转字符串指定区间[start, end]的字符*/public void reverseString(StringBuilder sb, int start, int end) {while (start < end) {char temp = sb.charAt(start);sb.setCharAt(start, sb.charAt(end));sb.setCharAt(end, temp);start++;end--;}}private void reverseEachWord(StringBuilder sb) {int start = 0;int end = 1;int n = sb.length();while (start < n) {while (end < n && sb.charAt(end) != ' ') {end++;}reverseString(sb, start, end - 1);start = end + 1;end = start + 1;}}
}
复杂度分析
  • 时间复杂度:(O(n)),其中 n 是字符串的长度。去除空格、反转字符串和反转单词的操作都需要遍历字符串一次。
  • 空间复杂:(O(n)),主要用于存储 StringBuilder 中的字符。

解法二:创建新字符数组填充

class Solution {public String reverseWords(String s) {//源字符数组char[] initialArr = s.toCharArray();//新字符数组char[] newArr = new char[initialArr.length + 1];//下面循环添加"单词 ",最终末尾的空格不会返回int newArrPos = 0;//i来进行整体对源字符数组从后往前遍历int i = initialArr.length - 1;while (i >= 0) {while (i >= 0 && initialArr[i] == ' ') {i--;}  //跳过空格//此时i位置是边界或!=空格,先记录当前索引,之后的while用来确定单词的首字母的位置int right = i;while (i >= 0 && initialArr[i] != ' ') {i--;}//指定区间单词取出(由于i为首字母的前一位,所以这里+1,),取出的每组末尾都带有一个空格for (int j = i + 1; j <= right; j++) {newArr[newArrPos++] = initialArr[j];if (j == right) {newArr[newArrPos++] = ' '; //空格}}}//若是原始字符串没有单词,直接返回空字符串;若是有单词,返回0-末尾空格索引前范围的字符数组(转成String返回)if (newArrPos == 0) {return "";} else {return new String(newArr, 0, newArrPos - 1);}}
}
复杂度分析
  • 时间复杂度:(O(n)),需要遍历源字符数组一次。
  • 空间复杂度:(O(n)),主要用于存储新字符数组。

解法三:双反转 + 移位

class Solution {/*** 思路:* ①反转字符串  "the sky is blue " => " eulb si yks eht"* ②遍历 " eulb si yks eht",每次先对某个单词进行反转再移位* 这里以第一个单词进行为演示:" eulb si yks eht" ==反转=> " blue si yks eht" ==移位=> "blue si yks eht"*/public String reverseWords(String s) {//步骤1:字符串整体反转(此时其中的单词也都反转了)char[] initialArr = s.toCharArray();reverse(initialArr, 0, s.length() - 1);int k = 0;for (int i = 0; i < initialArr.length; i++) {if (initialArr[i] == ' ') {continue;}int tempCur = i;while (i < initialArr.length && initialArr[i] != ' ') {i++;}for (int j = tempCur; j < i; j++) {if (j == tempCur) { //步骤二:二次反转reverse(initialArr, tempCur, i - 1); //对指定范围字符串进行反转,不反转从后往前遍历一个个填充有问题}//步骤三:移动操作initialArr[k++] = initialArr[j];if (j == i - 1) { //遍历结束//避免越界情况,例如=> "asdasd df f",不加判断最后就会数组越界if (k < initialArr.length) {initialArr[k++] = ' ';}}}}if (k == 0) {return "";} else {//参数三:以防出现如"asdasd df f"=>"f df asdasd"正好凑满不需要省略空格情况return new String(initialArr, 0, (k == initialArr.length) && (initialArr[k - 1] != ' ') ? k : k - 1);}}public void reverse(char[] chars, int begin, int end) {for (int i = begin, j = end; i < j; i++, j--) {chars[i] ^= chars[j];chars[j] ^= chars[i];chars[i] ^= chars[j];}}
}
复杂度分析
  • 时间复杂度:(O(n)),需要多次遍历字符数组,但总的时间复杂度仍为线性。
  • 空间复杂度:(O(n)),主要用于存储字符数组。

解法四:对 String 的 char [] 数组操作

class Solution {//用 char[] 来实现 String 的 removeExtraSpaces,reverse 操作public String reverseWords(String s) {char[] chars = s.toCharArray();//1.去除首尾以及中间多余空格chars = removeExtraSpaces(chars);//2.整个字符串反转reverse(chars, 0, chars.length - 1);//3.单词反转reverseEachWord(chars);return new String(chars);}//1.用 快慢指针 去除首尾以及中间多余空格,可参考数组元素移除的题解public char[] removeExtraSpaces(char[] chars) {int slow = 0;for (int fast = 0; fast < chars.length; fast++) {//先用 fast 移除所有空格if (chars[fast] != ' ') {//在用 slow 加空格。 除第一个单词外,单词末尾要加空格if (slow != 0)chars[slow++] = ' ';//fast 遇到空格或遍历到字符串末尾,就证明遍历完一个单词了while (fast < chars.length && chars[fast] != ' ')chars[slow++] = chars[fast++];}}//相当于 c++ 里的 resize()char[] newChars = new char[slow];System.arraycopy(chars, 0, newChars, 0, slow);return newChars;}//双指针实现指定范围内字符串反转,可参考字符串反转题解public void reverse(char[] chars, int left, int right) {if (right >= chars.length) {System.out.println("set a wrong right");return;}while (left < right) {chars[left] ^= chars[right];chars[right] ^= chars[left];chars[left] ^= chars[right];left++;right--;}}//3.单词反转public void reverseEachWord(char[] chars) {int start = 0;//end <= s.length() 这里的 = ,是为了让 end 永远指向单词末尾后一个位置,这样 reverse 的实参更好设置for (int end = 0; end <= chars.length; end++) {// end 每次到单词末尾后的空格或串尾,开始反转单词if (end == chars.length || chars[end] == ' ') {reverse(chars, start, end - 1);start = end + 1;}}}
}
复杂度分析
  • 时间复杂度:(O(n)),每个步骤都需要遍历字符数组一次。
  • 空间复杂度:(O(n)),主要用于存储新的字符数组。

总结

以上四种解法都可以解决翻转字符串里单词的问题,时间复杂度均为 (O(n)),空间复杂度均为 (O(n))。解法一和解法四的思路较为相似,都是先处理空格,再进行反转操作;解法二通过创建新数组的方式从后往前填充单词;解法三则采用双反转和移位的策略。在实际应用中,可以根据具体需求和代码风格选择合适的解法。

http://www.dtcms.com/a/502568.html

相关文章:

  • 佛山微网站如何让新网站快速收录
  • 国外免费推广网站有哪些带着购物系统回到80年代
  • 企业网站建设要多百度提交网址
  • 中国icp备案网站seo关键词排名优化app
  • 网站建设后怎么做主页数据分析工具
  • 网站建设程序制作大数据网站建设费用
  • 成都建设网站专业公司中小型网站建设信息
  • 网站域名后缀代表什么意思越秀金融大厦
  • 福建建设执业资格注册管理中心网站上海做外贸网站的公司
  • 本地南京网站建设重庆免费网站推广软件
  • 网站建设单元格边距北京网站建设推
  • 网站建设厘金手指排名二一建材 东莞网站建设
  • 福田网站建设龙岗网站建设网站建设管理工作情况汇报
  • 网站设计要求 优帮云推广平台网站热狗网
  • 网站ico如何添加番禺广州网站建设
  • 搭建网站 软件长沙网站建设软件
  • 微擎 网站开发工具wordpress修改文章浏览次数
  • 秦皇岛网站制作人才招聘公司网络营销
  • 丈哥seo博客工具杭州seo招聘
  • 做网站和做app那个简单工作室网站需要备案吗
  • 网站平台建设投资费用清单女装网站模板
  • 路由器带u盘接口的做网站软件制作流程
  • 网站名是什么dw超链接自己做的网站
  • 怎么样给一个网站做自然排名网站开发交易
  • 天津网站开发建设公司做网站不用tomcat行吗
  • 纯免费建站做情侣网站
  • 织梦网站版本济南百度推广开户
  • 网站建设交流平台网站开发的需求分析书
  • 国外企业网站怎么做临漳网站建设
  • 网站建设网站定制一级a做爰片免播放器网站