题目信息
给定一个句子,句子中每个单词之间用空格隔开,给定一个单词范围,翻转范围内单词的顺序。如给定一个句子 i am a student. 给定单词范围 1 3,翻转后结果为 i student. a am
- 示例 输入 i am a student. 1 3
- 示例 输出 i student. a am
题解
根据题目信息,大致可以得出以下信息:
- 须接收三个参数信息,给到程序使用
- 单词之间都是空格隔开的,句子给定后,须要使用split来分割单词
- 遍历分割后的单词,将给定范围内的单词逆转顺序
编码
package com.questionbank.nowcoder;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class ReverseControlWords {
public static void main(String[] args) throws NumberFormatException, IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
String input;
// 定义索引位置,方便接收参数值
int index = 0;
// 定义三个变量,分别接收句子,起始和结束索引范围
String sentence = null;
int start = 0;
int end = 0;
while ((input = br.readLine()) != null) {
// 根据不同索引位置,将接收的输入值赋给不同变量
if (index == 0) {
sentence = input;
} else if (index == 1) {
start = Integer.valueOf(input);
} else {
// 在拿到第三个变量值后,进行逆序处理
end = Integer.valueOf(input);
reverseSentence(sentence, start, end);
}
// 参数位置后移
index++;
// 逆序后,索引置0
if (index == 3) {
index = 0;
}
}
}
public static void reverseSentence(String sentence, int start, int end) {
String[] words = sentence.split(" ");
StringBuilder sb = new StringBuilder();
// 遍历单词数组
for (int i=0; i<words.length; i++) {
// i等于start且小于end时,对单词逆序处理
if (i == start && i<end) {
String tmp = words[i];
words[i] = words[end];
words[end] = tmp;
// 逆序后,start位置后移,end位置前移
start++;
end--;
}
sb.append(words[i]).append(" ");
}
// 输出截取后的结果值
System.out.println(sb.substring(0, sb.length()-1));
}
}