news 2026/1/19 7:14:12

Question:反转字符串中的字符(java)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Question:反转字符串中的字符(java)

题目:

在解题之前我想先说明一下scanner.next()与scanner.nextLine()的区别:

scanner.next():读取“单词”(以空白分隔)。1:跳过输入开头的所有空白字符(空格、换行、制表符等)。2:从第一个非空白字符开始读取,直到遇到下一个空白字符为止,返回读取的字符串。3:不会处理换行符,如果输入最后是换行符,该换行符会留在输入缓冲区中。

scanner.nextLine():读取“整行”(以换行为分隔)。1:读取输入中从当前位置到换行符\n为止的所有字符(包括中间的空格、制表符)。2:读取完成后,会将换行符从输入缓冲区中移除(消耗换行符)。3:如果当前位置就是换行符(比如前一个方法留下了换行符),会直接返回空字符串。

由于该题中可能含有空格,所以我们应使用nextLine()方法。

解一:获取字符串,创建一个可变字符数组,将字符串的内容递给数组中,StringBuilder.reverse()方法是一个高效的原地反转字符序列的方法,然后调用该方法,反转字符串进行输出。

import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scan = new Scanner(System.in); String str=scan.nextLine(); StringBuilder sb=new StringBuilder(str); System.out.print(sb.reverse()); scan.close(); } }

解二:获取该字符串,调用toCharArray()方法将字符串转为字符数组,for循坏遍历字符数组,设立一个中间值temp来将min和max对应的字符进行调换。(这里想提醒:for循坏执行n/2时字符调换已经结束,如果执行n的话说明调换了两次又变回原来的顺序,导致出错。所以在这里min++和max--同时进行)。最后对数组进行遍历输出。代码有如下两种:

import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scan = new Scanner(System.in); String str = scan.nextLine(); char[] Arr= str.toCharArray(); for(int min = 0,max=Arr.length-1;min<=max;min++,max--){ char temp=Arr[min]; Arr[min]=Arr[max]; Arr[max]=temp; } for(int i = 0; i<Arr.length;i++){ System.out.print(Arr[i]); } scan.close(); } }
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scan = new Scanner(System.in); String str = scan.nextLine(); char[] arr = str.toCharArray(); for (int i = 0; i < arr.length / 2; i++) { char temp = arr[i]; arr[i] = arr[arr.length -1 -i]; arr[arr.length -1 -i] = temp; } System.out.print(new String(arr)); scan.close(); } }

解三(自己的解法):获取字符串,创建一个可变字符数组,对字符串倒序遍历将各个字符追加到可变数组中(遍历时应注意对下标i的初始与结束判断)。最后打印输出。

import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scan = new Scanner(System.in); Scanner scanner = new Scanner(System.in);//获取字符串 String x = scanner.nextLine(); StringBuilder sb = new StringBuilder();//创建一个可变字符数组 for (int i = x.length()-1;i>=0;i--){//对字符串倒序遍历 char a = x.charAt(i);//将i号下标字符追加到可变字符数组中 sb.append(a); } System.out.println(sb);//输出 scan.close(); } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/16 13:42:09

终极指南:5分钟快速上手iogame游戏服务器框架

终极指南&#xff1a;5分钟快速上手iogame游戏服务器框架 【免费下载链接】ioGame 项目地址: https://gitcode.com/gh_mirrors/io/ioGame 想要构建高性能的Java游戏服务器却苦于复杂的网络编程和并发处理&#xff1f;iogame游戏服务器框架正是您需要的解决方案&#xf…

作者头像 李华
网站建设 2026/1/18 8:38:01

一人公司之父Dan Koe:用8条反骨法则重塑你的职业生涯

从“社畜”到“独狼”的思维转变你是否也曾感觉自己被困在朝九晚五的传统工作中&#xff0c;日复一日地重复&#xff0c;像一个身不由己的“社畜”&#xff1f;渴望改变&#xff0c;却又不知从何下手。Dan Koe&#xff0c;被誉为“一人公司之父”&#xff0c;他的理念为无数寻求…

作者头像 李华
网站建设 2026/1/19 0:43:23

Kotaemon配置热更新机制:无需重启服务的变更生效

Kotaemon配置热更新机制&#xff1a;无需重启服务的变更生效 在企业级智能对话系统的实际部署中&#xff0c;一个看似微小的配置调整&#xff0c;往往可能引发一场“服务雪崩”——修改参数、提交代码、等待构建、重启服务、验证功能……这一连串流程不仅耗时&#xff0c;更致…

作者头像 李华
网站建设 2026/1/14 19:21:04

还在问CTF是啥?这篇“网安扫盲贴”,带你从入门到入坑!

还在问CTF是啥&#xff1f;这篇“网安扫盲贴”&#xff0c;带你从入门到入坑&#xff01; CTF&#xff1f;听起来像某种神秘代码&#xff0c;新手该如何玩转&#xff1f; CTF&#xff08;Capture The Flag&#xff09;&#xff0c;江湖人称“夺旗赛”&#xff0c;在网络安全界…

作者头像 李华
网站建设 2026/1/17 23:24:54

5分钟搞定AI字幕生成:ComfyUI终极配置完整指南 [特殊字符]

5分钟搞定AI字幕生成&#xff1a;ComfyUI终极配置完整指南 &#x1f680; 【免费下载链接】ComfyUI_SLK_joy_caption_two ComfyUI Node 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI_SLK_joy_caption_two 还在为视频字幕制作烦恼吗&#xff1f;ComfyUI字幕生成…

作者头像 李华