Отменить заданное предложение в Java

Вы хотите использовать Timer , если хотите указать задержку для действия.

13
задан Tot Zam 11 August 2017 в 20:42
поделиться

8 ответов

Я тоже попробую: вот версия, использующая стек и сканер:

String input = "this is interview question";
Scanner sc = new Scanner(input);
Stack<String> stack = new Stack<String>();

while(sc.hasNext()) {
    stack.push(sc.next());
}

StringBuilder output = new StringBuilder();

for(;;) { // forever
    output.append(stack.pop());

    if(stack.isEmpty()) {
        break; // end loop
    } else {
        output.append(" ");
    }
}
3
ответ дан 1 December 2019 в 17:11
поделиться

Вы разделяете строку пробелом, а затем перебираете ее в обратном направлении, чтобы собрать перевернутое предложение.

String[] words =  "This is interview question".split(" ");

String rev = "";
for(int i = words.length - 1; i >= 0 ; i--)
{
   rev += words[i] + " ";
}

// rev = "question interview is This "

// can also use StringBuilder:
StringBuilder revb = new StringBuilder();
for(int i = words.length - 1; i >= 0 ; i--)
{
   revb.append(words[i]);
   revb.append(" ");
}
// revb.toString() = "question interview is This "
24
ответ дан 1 December 2019 в 17:11
поделиться

Просто разделите его на пробел в массив строк, затем переберите массив в обратном порядке и создайте выходную строку.

String input = "This is interview question";
String output = "";
String[] array = input.split(" ");
for(int i = array.length-1; i >= 0; i--)
{
    output += array[i];
    if (i != 0) { output += " "; }
}
6
ответ дан 1 December 2019 в 17:11
поделиться

Просто отличаться: рекурсивное решение. Не добавляет лишних пробелов.

public static String reverse(String s) {
   int k = s.indexOf(" ");
   return k == -1 ? s : reverse(s.substring(k + 1)) + " " + s.substring(0, k);
}


System.out.println("[" + reverse("This is interview question") + "]");
// prints "[question interview is This]"

Я также улучшу решение split , используя вместо него \ b (это так очевидно!).

    String[] parts = "Word boundary is better than space".split("\\b");
    StringBuilder sb = new StringBuilder();
    for (int i = parts.length; i --> 0 ;) {
        sb.append(parts[i]);
    }
    System.out.println("[" + sb.toString() + "]");
    // prints "[space than better is boundary Word]"
19
ответ дан 1 December 2019 в 17:11
поделиться
public class ReverseString {

    public void reverse(String[] source) {

        String dest = "";
        for (int n = source.length - 1; n >= 0; n--) {
            dest += source[n] + " ";
        }
        System.out.println(dest);

    }

    public static void main(String args[]) {
        ReverseString rs = new ReverseString();
        String[] str = "What is going on".split(" ");
        rs.reverse(str);

    }

}
2
ответ дан 1 December 2019 в 17:11
поделиться

каждый скучный бит java:

List<String> l = new ArrayList<String>(Arrays.asList("this is an interview question".split("\\s")));
Collections.reverse(l);
StringBuffer b = new StringBuffer();
for( String s : l ){
    b.append(s).append(' ');
}
b.toString().trim();

в Groovy он немного читабельнее:

"this is an interview question"
    .split("\\s")
    .reverse()
    .join(' ')
3
ответ дан 1 December 2019 в 17:11
поделиться

Божо уже дал отличный ответ для Java, но если вам когда-нибудь понадобится решить эту проблему без методов Java API:

Чтобы отменить, вы можете просто помещать отдельные слова в стек и возвращать их все обратно, когда слов не осталось.

(Для большей ясности, Java действительно предоставляет класс Stack , поэтому этот метод также можно использовать в Java).

6
ответ дан 1 December 2019 в 17:11
поделиться
String[] words = sentence.split(" ");
String[] reversedWords = ArrayUtils.reverse(words);
String reversedSentence = StringUtils.join(reversedWords, " ");

(с использованием ArrayUtils и StringUtils из commons-lang, но это простые методы для написания - всего несколько циклов)

23
ответ дан 1 December 2019 в 17:11
поделиться
Другие вопросы по тегам:

Похожие вопросы: