Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Начинающим";
Текущий архив: 2010.01.31;
Скачать: [xml.tar.bz2];

Вниз

Внимание! Тест на интуицию :)   Найти похожие ветки 

 
HRustBB   (2009-12-06 12:36) [0]

Есть задача:
дано четыре числа 1 2 4 8. и есть число, назовем его Х, которое равно сумме двух, трех, четырех из этих чисел, либо какому нибудь одному из них. Дак вот, нужно определить из каких чисел из предложенного ряда сложенно Х. Да и кстати каждое из четырех указанных чисел участвует в сумме только один раз. Нужен алгоритм хотябы.


 
McSimm ©   (2009-12-06 12:43) [1]

Двоичное представление числа отвечает на ваш вопрос.


 
HRustBB   (2009-12-06 12:44) [2]

так так так, попродробней пожалуйсто :)


 
HRustBB   (2009-12-06 12:55) [3]

ааа, comprento, спасибо досвиданья


 
AIK ©   (2009-12-06 12:55) [4]

сперва
бегоем по циклу сравниваем каждое число с Х
если не одно не равно то
бегоем по циклу сравниваем 1+другое число число с Х
если не одно не равно то
бегоем по циклу сравниваем 2+другое число число с Х
если не одно не равно то
бегоем по циклу сравниваем 3+другое число число с Х
если не одно не равно то
бегоем по циклу сравниваем 4+другое число число с Х
если не одно не равно то
бегоем по циклу сравниваем 1+2+другое число число с Х
если не одно не равно то
бегоем по циклу сравниваем 1+3+другое число число с Х
если не одно не равно то
..... и.т.д.
Можно оптимальнее сделать но пока первое что мне пришло в голову


 
Inovet ©   (2009-12-06 13:04) [5]

> [4] AIK ©   (06.12.09 12:55)
> бегоем по циклу

А в нём shr 1 and 1


 
McSimm ©   (2009-12-06 13:16) [6]


> AIK ©   (06.12.09 12:55) [4]


Число X, записанное в двоичном виде будет иметь в каждом разряде ноль или один. Позиции единиц соответствует искомым слагаемым в задаче.
Например X=12. Двоичная запись 1100 -> 1*8 + 1*4 + 0*2 + 0*1


 
Юрий Зотов ©   (2009-12-07 00:33) [7]

> Тест на интуицию

:o)


 
KilkennyCat ©   (2009-12-07 00:44) [8]

на интуицию препода.


 
Германн ©   (2009-12-07 00:54) [9]


> Юрий Зотов ©   (07.12.09 00:33) [7]
>
> > Тест на интуицию
>
> :o)

Всё-таки да. На интуицию. :)


 
icWasya ©   (2009-12-07 09:54) [10]

А если хочешь блеснуть эрудицией, то это называется задачей о рюкзаке, в которой исходные числа - произвольны.  
И тогда она решается, как описано в [4].
А есть частный случай, когда в исходном наборе каждое последующее число больше суммы всех предыдущих.
Исходные числа 1,2,4,8 удовлетворяют этому условию
Тогда задача решается так:
1)Берём самое большое число
2) если Х больше этого числа, То это число входит в сумму; Уменьшаем Х на число.
3)выбрасываем число из набора.
4) Если чисел больше нет, то закончить, иначе повторить с 1)



Страницы: 1 вся ветка

Форум: "Начинающим";
Текущий архив: 2010.01.31;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.47 MB
Время: 0.006 c
6-1211916995
Darth Avenger
2008-05-27 23:36
2010.01.31
ServerSocket и ClientSocket - "склеивание" принятых строк


2-1260337028
Леонид Артюхов
2009-12-09 08:37
2010.01.31
Как наложить одну картинку на другую?


2-1260359041
webpauk
2009-12-09 14:44
2010.01.31
Рекурсивная функция и уровень рекурсии


15-1259398978
12
2009-11-28 12:02
2010.01.31
Антивирус. Коряво обновляется nod32. 4.0467.0. Помогите чем нибуд


15-1258984807
Unknown user
2009-11-23 17:00
2010.01.31
Кнопка Favorites в диалогах Open/Save в Windows XP





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский