Обращенные слова
В методе main с консоли считать имя файла, который содержит слова, разделенные пробелами.
Найти в тексте все пары слов, которые являются обращением друг друга. Добавить их в result.
Использовать StringBuilder.
Пример содержимого файла
рот тор торт о
о тот тот тот
Вывод:
рот тор
о о
тот тот
Требования:
1. Метод main должен считывать имя файла с клавиатуры.
2. В методе main должен быть использован StringBuilder
3. Список result должен быть заполнен корректными парами согласно условию задачи.
4. В классе Solution должен содержаться вложенный класс Pair.
5. В классе Pair должен быть объявлен конструктор без параметров (или конструктор по умолчанию).
public class Solution {
public static List<Pair> result = new LinkedList<>();
public static void main(String[] args) throws IOException {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
String name = reader.readLine();
BufferedReader fileReader = new BufferedReader(new FileReader(name));
ArrayList<String> list = new ArrayList<>();
while (fileReader.ready()){
String[] str = fileReader.readLine().split("\\s");
for (String s:str) {
list.add(s);
}
}
reader.close();
fileReader.close();
for (int i =1; i< list.size()-1;i++) {
StringBuilder sb = new StringBuilder(list.get(i));
String reversWord = sb.reverse().toString().trim();
for(int j = 0;j<list.size();j++){
if(reversWord.equals(list.get(j))){
Pair pair = new Pair();
pair.first=list.get(i);
pair.second=list.get(j);
result.add(pair);
list.remove(i);
list.remove(j);
i--;
j--;
break;
}
}
}
}
public static class Pair {
String first;
String second;
public Pair() {
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Pair pair = (Pair) o;
if (first != null ? !first.equals(pair.first) : pair.first != null) return false;
return second != null ? second.equals(pair.second) : pair.second == null;
}
@Override
public int hashCode() {
int result = first != null ? first.hashCode() : 0;
result = 31 * result + (second != null ? second.hashCode() : 0);
return result;
}
@Override
public String toString() {
return first == null && second == null ? "" :
first == null && second != null ? second :
second == null && first != null ? first :
first.compareTo(second) < 0 ? first + " " + second : second + " " + first;
}
}
}
package com.javarush.task.task22.task2207;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
public class Solution {
public static List<Pair> result = new LinkedList<>();
public static void main(String[] args) throws IOException {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
String name = reader.readLine();
BufferedReader fileReader = new BufferedReader(new FileReader(name));
ArrayList<String> list = new ArrayList<>();
while (fileReader.ready()){
String[] str = fileReader.readLine().split("\\s");
for (String s:str) {
list.add(s);
}
}
reader.close();
fileReader.close();
for (int i =1; i< list.size()-1;i++) {
StringBuilder sb = new StringBuilder(list.get(i));
String reversWord = sb.reverse().toString().trim();
for(int j = 0;j<list.size();j++){
if(reversWord.equals(list.get(j))){
Pair pair = new Pair();
pair.first=list.get(i);
pair.second=list.get(j);
result.add(pair);
list.remove(i);
list.remove(j);
i--;
j--;
break;
}
}
}
}
public static class Pair {
String first;
String second;
public Pair() {
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Pair pair = (Pair) o;
if (first != null ? !first.equals(pair.first) : pair.first != null) return false;
return second != null ? second.equals(pair.second) : pair.second == null;
}
@Override
public int hashCode() {
int result = first != null ? first.hashCode() : 0;
result = 31 * result + (second != null ? second.hashCode() : 0);
return result;
}
@Override
public String toString() {
return first == null && second == null ? "" :
first == null && second != null ? second :
second == null && first != null ? first :
first.compareTo(second) < 0 ? first + " " + second : second + " " + first;
}
}
}