Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 28.05.2013
Сообщений: 50

Выявление одинаковых наборов чисел в строке

12.04.2016, 15:16. Показов 795. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.

Есть задание - обнаружить одинаковые наборы целых чисел в строках, числа в наборе записываются через запятую. Т.е. два набора одинаковы - когда содержат одинаковые числа, независимо от их позиции.

Например, на вход идут две строки (наборы):

"5, 8, 3" и "8, 3, 5" - одинаковые наборы.
"5, 8, 3" и "5, 8 ,3 ,1" - разные.


Из реализации, мне пока на ум приходит только разделять строку на массив через метод split(","), а потом сравнивать уже получившиеся массивы. Но что-то кажется, что такой способ будет не очень эффективен.
Или, для простоты, вначале упорядочить массивы (по возрастанию, например) а потом уже находить одинаковые массивы, но это займет ещё больше времени, наверное.

Как эту задачу можно эффективно реализовать?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.04.2016, 15:16
Ответы с готовыми решениями:

Количество одинаковых чисел в строке StringGrid
Помогите пожалуйста решить задачку. Есть стринг грид заполнений примерно так 2,5 2,5 2,5 2,5 5 7 6 8 2,5 2,5 2,5 2,5 6 5 7 8 2 1 3...

Составить программу для подсчета одинаковых чисел в строке
Нужно составить программу для подсчета одинаковых чисел в строке.

Нахождение в строке/столбце/диагонали матрицы последовательностей одинаковых чисел
Имеется двумерный массив с целыми элементами - единицами и двойками. Задача состоит в том, чтобы при нахождении в строке/столбце/диагонали...

4
1123 / 794 / 219
Регистрация: 15.08.2010
Сообщений: 2,185
12.04.2016, 15:39
Цитата Сообщение от XlorD59 Посмотреть сообщение
Из реализации, мне пока на ум приходит только разделять строку на массив через метод split(","), а потом сравнивать уже получившиеся массивы. Но что-то кажется, что такой способ будет не очень эффективен.
Или, для простоты, вначале упорядочить массивы (по возрастанию, например) а потом уже находить одинаковые массивы, но это займет ещё больше времени, наверное.
разделить, упорядочить, сравнить.
И решение неплохое, и код понятен будет.

Можно заменить сортировку подсчетом элементов, но нужно ли?
1
1 / 1 / 0
Регистрация: 28.05.2013
Сообщений: 50
12.04.2016, 16:02  [ТС]
КОП,

т.е. такая реализация вполне эффективна?

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
    public static void main(String[] args) {
 
        String set1 = "1,2,3";
        String set2 = "2,1,3";
        String set3 = "1,2,3,4";
 
        int[] numArr1 = Arrays.stream(set1.split(",")).mapToInt(Integer::parseInt).toArray();
        int[] numArr2 = Arrays.stream(set2.split(",")).mapToInt(Integer::parseInt).toArray();
 
        Arrays.sort(numArr1);
        Arrays.sort(numArr2);
 
        if (Arrays.equals(numArr1, numArr2)) {
            System.out.println("Массивы равны");
        } else System.out.println("Массивы не равны");
    }

Можно ли в принципе как-то это оформить лучше с точки зрения ООП? А если понадобится превратить это в библиотеку (которая будет получать на вход файл со строками и выдавать результат)?
0
1123 / 794 / 219
Регистрация: 15.08.2010
Сообщений: 2,185
12.04.2016, 16:11
Цитата Сообщение от XlorD59 Посмотреть сообщение
т.е. такая реализация вполне эффективна?
думаю да
Цитата Сообщение от XlorD59 Посмотреть сообщение
Можно ли в принципе как-то это оформить лучше с точки зрения ООП? А если понадобится превратить это в библиотеку (которая будет получать на вход файл со строками и выдавать результат)?
как самостоятельный класс вряд ли. Если только в стиле класса со вспомогательными статическими методами (пример: Math)
0
1 / 1 / 0
Регистрация: 28.05.2013
Сообщений: 50
12.04.2016, 18:15  [ТС]
Ок, небольшое дополнение к моему вопросу.

Как правильно считать данные из файла?

В файле данные в таком виде:

1, 2, 3, 4
78
4, 3, 2, 1, 6, 7
34, 45

Нужно разбить вход по табуляции и превратить элементы строки в массивы. Т.е. в данном случае на выходе должно получиться 4 одномерных массива:

[1 2 3 4]
[78]
[4 3 2 1 6 7]
[34 45]


Собственно, как считать данные и превратить полученные строки в массивы вопросов не вызывает
Java
1
2
3
FileInputStream inputFile= new FileInputStream("//input.txt");
 
int[] array = Arrays.stream(set.split(", ")).mapToInt(Integer::parseInt).toArray();

Мне непонятно как считывать данные построчно (каждая строка - новый массив) и как проверять на лишние табуляции, переносы строки, пробелы, неправильные символы (допустимы только целые числа) и тому подобное.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.04.2016, 18:15
Помогаю со студенческими работами здесь

Выявление и подсчет простых чисел
Задана задача C# : Выход: Please enter the upper bound: 10000 1 2 3 ...... ...... 9967 9973

Выявление четных чисел на Assembler[masm]
С клавиатуры вводится целое 16-битное беззнаковое число A. Напишите программу, печатающую слово Count столько раз, сколько раз встречаются...

Использование уже готовых наборов в построении новых наборов
Здравствуйте. Я новичек в jquery, так что вопрос начального уровня var $table = $('table'); var $tr = $('table tr') Возможно...

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

Объясните некоторые места в коде. Выявление самого частого символа в строке. Внизу после кода то, что меня интересует
class Program { static void Main() { Console.WriteLine("==============="); Console.WriteLine("Введите текст:...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru