字符逆序

Posted 山河执手

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了字符逆序相关的知识,希望对你有一定的参考价值。

字符逆序

题目描述

将一个字符串str的内容颠倒过来,并输出。str的长度不超过100个字符。

输入

输入包括一行。 第一行输入的字符串。

输出

输出转换好的逆序字符串。

样例输入

I am a student

样例输出

tneduts a ma I

算法思想

这是一条蓝桥杯的入门题,本身是不难的,但是通过率只有51%,问题可能就出在对于常用的操作字符串的方法不熟悉。所以以下列出了常用的方法。

#String
1.charAt(int i);//返回索引i处的字符
2.toCharArray();//返回此字符串的字符数组
3.equals(String anotherString)//判断两个字符串是否相等,相等返回true否则返回false
4.equalsIgnoreCase(String str)//同上,不区分大小写。
5.indexOf(int ch);// 返回指定字符在此字符串中第一次出现的索引
6.lastIndexOf(int ch);//返回指定字符在此字符串最后一次出现的索引
7.split(String regex); // 根据正则表达式拆分
8.substring(int beginIndex, int endIndex)//返回从begin开始到end-1结束的子串
9.replaceAll(String s1,String s2);//用s2替换目标字符串中出现的所有s1
10.toUpperCase(); //将此字符串中的所有字母都换为大写
11.toLowerCase()//将此字符串中的所有字母都换为小写
#StringBuilder
1.StringBuilder();//构建一个空的可变字符串。
2.StringBuilder(String str);//构建一个值为str的可变字符串。
3.charAt(int i);// 返回索引i位置的字符
4.length();//返回此字符串的长度
5.append(String str);//在此字符串追加str。
6.deleteCharAt(int index);//移除指定索引上的char
7.setCharAt(int index, char ch);//将指定索引处的字符替换为ch
8.indexOf(String str);//返回子字符串第一次出现的索引
9.reverse();//将此字符串反转
10.substring(int start);//返回此字符串从start开始至length-1结束的String

注意点

我们要注意next()和nextLine()的区别,这也是为什么我写这篇博客的主要原因。

next()方法在读取内容时,会过滤掉有效字符前面的无效字符,对输入有效字符之前遇到的空格键、Tab键或Enter键等结束符,next()方法会自动将其过滤掉;只有在读取到有效字符之后,next()方法才将其后的空格键、Tab键或Enter键等视为结束符;所以next()方法不能得到带空格的字符串。

nextLine()方法字面上有扫描一整行的意思,它的结束符只能是Enter键,即nextLine()方法返回的是Enter键之前没有被读取的所有字符,它是可以得到带空格的字符串的。

代码实现

import java.util.Scanner;
import java.util.Stack;

public class Main 
	public static void main(String[] args) 
		Scanner scanner=new Scanner(System.in);
		String s=scanner.nextLine();//nextLine与next的区别
		char[] arr=s.toCharArray();
		Stack<Character> stack=new Stack();
		for(int i=0;i<arr.length;i++) 
			stack.add(arr[i]);
		
		while(!stack.isEmpty()) 
			System.out.print(stack.pop());
		
	

运行结果

以上是关于字符逆序的主要内容,如果未能解决你的问题,请参考以下文章

编写程序,输入字符串(包含空格),统计其中单词的个数,单词之间以一个或多个空格分隔。

将字符串依照单词逆序

字符串练习题:句子的逆序

ECMAScript 6 模板字面量的常见用法

华为机试HJ13:句子逆序

字符串内子字符串的逆序算法