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

个人外贸网站建设移动端网站定制

个人外贸网站建设,移动端网站定制,深圳建设一个网站制作公司,用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/556117.html

相关文章:

  • 一个旅游网站建设需求站群建站
  • 包装网站开发Net网站开发多少钱
  • 全球采购平台seo网站推广案例
  • 广西建工集团冶金建设公司的网站网页设计师培训学院
  • 做网站通常又什么开发完成电子商务网站建设要多少钱
  • 厦门专业的网站建设WordPress国外赚钱
  • 昆明网站建设推荐天津和平做网站多少钱
  • 深圳企搜网站建设做新零售这些注册网站和找货源6
  • 农业网站建设公司如何评价企业网站推广效果?
  • 婚礼做的好的婚庆公司网站营销类网站 英文
  • 哪些网站教你做系统个人网站二级域名做淘宝客
  • 佛山商业网站建设wordpress手机版登录
  • 网站建设有利于网站建设php书籍
  • 上海十大网站建wordpress首页聚合
  • 广州购物网站公司地址小公司做网站多少钱
  • 企业做自己的网站要注意什么动态页面设计
  • 网站设计官网做练习题的网站
  • 站长工具seo综合查询权重二手交易网站建设内容策划
  • 南宁响应式网站制作宁波做网站软件
  • 用ps做招生网站如今做哪个网站能致富
  • 传奇网站模板免费下载站酷设计师网站
  • 湖南大型网站建设html网站系统
  • 网络违法犯罪举报网站加盟教育培训哪个好
  • 新乡网站网站建设网站备案人什么意思
  • 南充城市建设投诉网站网站做友链有行业要求吗
  • 乌克兰设计网站建设云南建网站的公司
  • 英文网站报价网站建设安全需求
  • 天津团购鲜花的网站建设扬中网络公司
  • 中山cms建站模板wordpress关注公众号登录
  • 软件科技公司网站模板呼和浩特网站制作