6 / 6 / 3
Регистрация: 14.11.2016
Сообщений: 53
|
||||||
1 | ||||||
Оценить качество кода -- решение учебное задачи для начинающих09.01.2017, 23:55. Показов 1587. Ответов 5
Решил задачу для начинающих на acmp по Java.
Мой результат -- задача принята, но время выполнения -- 0,404 секунды, память -- 5,3 Мб. Лучший результат другого ученика -- время выполнения 0,149 секунды, память -- 1556 Кб. Как понятно, мой результат далёк от оптимального. Суть задачи: в текстовом файле вводится шесть целых чисел через пробел, например 5 1 7 8 9 10 Мы должны разделить строку на две и получить: 5 1 7 и вторую 8 9 10 Затем отсортировать каждую строку по уменьшению чисел, то есть получить 7 5 1 и 10 9 8 Затем нужно перемножить и сложить: 7 * 10 + 5 *9 + 1*8=70 +45 + 8 =123 Цифра 123 является ответом. Нужно записать её в файл output.txt Сама же начальная строка находится в файле input.txt Вот моё решение: Как можно сделать код лучше в плане избавления от говно-кода и как можно ускорить программу, чтобы приблизиться к лучшему результату в 0,149 секунды?
0
|
09.01.2017, 23:55 | |
Ответы с готовыми решениями:
5
Оценить качество кода -- решение учебное задачи для начинающих Оценить качество кода (читабельность и эффективность) Оценить качество кода написанного фреймворка Где можно оценить качество своего кода? |
1 / 1 / 0
Регистрация: 19.05.2015
Сообщений: 59
|
|
09.01.2017, 23:58 | 2 |
Скажу по поводу памяти-используешь слишком много массивов. Попробуй использовать меньше, перезаписывая информацию в них по мере нужды
1
|
4486 / 2721 / 485
Регистрация: 28.04.2012
Сообщений: 8,590
|
|
10.01.2017, 09:42 | 3 |
1
|
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
|
||||||
10.01.2017, 18:57 | 4 | |||||
Как-то сложно все.
1
|
6 / 6 / 3
Регистрация: 14.11.2016
Сообщений: 53
|
||||||
10.01.2017, 22:34 [ТС] | 5 | |||||
xoraxax, ваша программа не даёт верного ответа.
Давайте прогоним строку: 1 2 30 9 5 10 Нам нужно разбить строку на две: 1 2 30 и 9 5 10 Затем отсортировать, в результате чего получим: 30 2 1 и 10 9 5 А затем умножить и сложить, 30*10+2*9+1*5=323 -- правильный ответ. Именно такой ответ даст программа, если загнуть мой код. Я загнал ваш код и получил ответ: 290 Вот ваш код. Скорее всего, ошибка происходит здесь: Arrays.sort(left, Collections.reverseOrder()); Arrays.sort(right, Collections.reverseOrder()); Ваша программа сортирует left правильно (на выходе получается 30 2 1), а вот right почему-то она оставляет без изменений (на выходе получается не 10 9 5, как должно быть, а 9 5 10, то есть всё остаётся без изменений). В итоге умножение происходит так: 30*9+2*5+1*10=290 -- получается из-за того, что не происходит сортировки на right правильного ответа.
korvin_ Да, действительно вы правы, я опустил new Integer и всё работает. Спасибо за улучшение кода.
0
|
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
|
||||||
10.01.2017, 22:46 | 6 | |||||
Сообщение было отмечено vjg2017 как решение
Решение
че-то тупанул, строки сортируются - поэтому порядок другой
1
|
10.01.2017, 22:46 | |
10.01.2017, 22:46 | |
Помогаю со студенческими работами здесь
6
Калькулятор для начинающих, прошу оценить Как оценить качество PR? Java для начинающих , прошу оценить код Как оценить качество сайта? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |