按照索引范围翻转句子单词顺序

题目信息

给定一个句子,句子中每个单词之间用空格隔开,给定一个单词范围,翻转范围内单词的顺序。如给定一个句子 i am a student. 给定单词范围 1 3,翻转后结果为 i student. a am

  • 示例 输入 i am a student. 1 3
  • 示例 输出 i student. a am

题解

根据题目信息,大致可以得出以下信息:

  1. 须接收三个参数信息,给到程序使用
  2. 单词之间都是空格隔开的,句子给定后,须要使用split来分割单词
  3. 遍历分割后的单词,将给定范围内的单词逆转顺序

编码

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));
	}
}

猜你喜欢

转载自blog.csdn.net/magi1201/article/details/114462108
今日推荐