Inverta a ordem das palavras das frases de acordo com o intervalo do índice

Informação do tópico

Dada uma frase, cada palavra na frase é separada por um espaço, dado um intervalo de palavras, inverta a ordem das palavras no intervalo. Por exemplo, dada uma frase eu sou um estudante. Dado um intervalo de palavras de 1 a 3, o resultado após a inversão é i estudante. A am

  • Exemplo de entrada Eu sou um estudante. 1 3
  • Resultado de exemplo i aluno. A am

responder

De acordo com as informações do tópico, as seguintes informações podem ser derivadas aproximadamente:

  1. Três informações de parâmetro devem ser recebidas e usadas pelo programa
  2. As palavras são separadas por espaços. Após a frase ser dada, você precisa usar a divisão para dividir as palavras
  3. Percorra as palavras divididas e inverta a ordem das palavras em um determinado intervalo

codificação

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

 

Acho que você gosta

Origin blog.csdn.net/magi1201/article/details/114462108
Recomendado
Clasificación