0 / 0 / 0
Регистрация: 27.09.2016
Сообщений: 8
|
||||||
1 | ||||||
Жадный алгоритм27.09.2016, 12:08. Показов 3495. Ответов 11
Метки нет Все метки)
(
Добрый день.
Помогите, пожалуйста, понять, где затаилась ошибка. Это задачка на жадный алгоритм: пользователь вводит размер полагающейся сдачи, а программа должна рассчитать, какое минимальное количество монет можно выдать, располагая монетами номиналом 25с, 10с, 5с и 1с. Представленный ниже код считает сдачу, но через раз правильно, т.е. к примеру, сдачу 0,40$ и 0,43$ рассчитывает правильно, а 0,41$ и 0,42$ - нет, показывает всего 3 монеты. Я так понимаю, если бы формула рассчета была неправильная, неправильно бы считало все, а не через раз. Может где-то округляет неправильно? Буду очень благодарна за подсказки.
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
|
|
27.09.2016, 12:08 | |
Ответы с готовыми решениями:
11
Жадный алгоритм Жадный алгоритм Жадный алгоритм
|
59 / 59 / 53
Регистрация: 05.05.2013
Сообщений: 150
|
|
27.09.2016, 12:58 | 3 |
Возможно при вычислениях y,z,u необходимо явно преобразовать коэфициенты a,b,c к float.
0
|
553 / 361 / 206
Регистрация: 27.11.2014
Сообщений: 1,043
|
||||||
27.09.2016, 13:05 | 5 | |||||
0
|
0 / 0 / 0
Регистрация: 27.09.2016
Сообщений: 8
|
|
27.09.2016, 13:26 [ТС] | 6 |
К примеру, сдача составляет 0,41$. Минимальное количество монет: 1х25с, 1х10с, 1х5с и 1х1с, т.е. 4 монеты. Вместо этого выдает 3.
При этом, когда ввожу 0,43$ віводит правильный ответ - 6 монет.
0
|
0 / 0 / 0
Регистрация: 27.09.2016
Сообщений: 8
|
||||||
27.09.2016, 13:50 [ТС] | 8 | |||||
zer0mail, спасибо! int d = (int)(u+0.1); помогло, выводит правильный результат. Но при проверке не прошло при вводе 4,2$, вместо 18 монет выдает 23.
Можете объяснить, как это работает? Я рассуждала так:
ture, спасибо. Но для это пока выше моего уровня. У меня самые первые занятия, я пока 0.
0
|
0 / 0 / 0
Регистрация: 27.09.2016
Сообщений: 8
|
|
27.09.2016, 13:59 [ТС] | 10 |
Спасибо! Теперь работает все. Но теперь я вообще не понимаю как это работает((
После каждого вычисления я получаю не целое число, а число+0,1?
0
|
27.09.2016, 14:12 | 11 |
Просле этого:
float z = (change-a*quater-b*ten)/five; Вы получаете число с плавающей точкой, например 1.9999998... (дальше еще неважно что). int c = (int)z; отбрасывает дробную часть (0.9999998) и присваивает 'c' единицу. А int c = (int)(z+0.1) сначала получает 2.0999998, а уж потом отбрасывает дробную часть. Вместо 0.1 можно было использовать 0.01 или 0.0001, т.к. ошибки возникают в 5-6м знаке или дальше.
1
|
0 / 0 / 0
Регистрация: 27.09.2016
Сообщений: 8
|
|
27.09.2016, 14:20 [ТС] | 12 |
ааа, 0,1 добавляется до преобразования в целое число. Теперь понятно.
Большое спасибо за ликбез ![]()
0
|
27.09.2016, 14:20 | |
Помогаю со студенческими работами здесь
12
Жадный алгоритм С++
Жадный алгоритм (рюкзак) Жадный алгоритм на графе Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |