Loading...
o_ignatov avatar o_ignatov 54 Точки

BitWise Жокер

Здравейте колеги,

Готвите ли се за задачите с побитови? Ако да това може да ви е полезно.

Много често ми се налага да търся десетично число, чиято битова стойност ми върши работа. Има някои случай в които просто трябва да променя 1 бит на дадена позиция. Започнах да използвам побитовия запис: с 0b... или 0x... защото е по-човешко и защото нагледно виждам битовото число.
Детайли и примери:

https://stackoverflow.com/questions/12015598/how-to-set-unset-a-bit-at-specific-position-of-a-long

Друг номер, който вече всички знаем е как да си вземем бита на позиция Х. Шифтваме надясно числото Х пъти и го сравняваме с 1:

private static int getBit(int num, int position){
    return (num >> position) & 1;
}

Последното което намирам за супер полезно е печатенето на числото след всяка итерация. Веднъж разбереш ли какво трябва да се случва лесно можеш да си следиш итерациите:

System.out.println(Integer.toBinaryString(num));

Потърсих в Judge задачи с битове и намерих няколко. По интересното е, че първата задача от изпита ни се казва 01. Bit Snow. Който не вярва да потърси за думичката bit.

Задачата с битове от днешната подготовка я реших по метода на баба ми. Въртя и риплейсвам на 2 места. Има коментирани дъмпове за итерациите.

03. BitRoller

https://pastebin.com/saJYyw0x

Тагове:
2
Java Advanced 19/10/2017 15:38:57
o_ignatov:
Заключена тема
o_ignatov avatar o_ignatov 54 Точки

Искам да добавя още, че при принт в Hex String тестовете са с главна буква и минават ако не се тоъперкейсне стринга.

System.out.println(Integer.toHexString(sum).toUpperCase());
0
Можем ли да използваме бисквитки?
Ние използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Можете да се съгласите с всички или част от тях.
Назад
Функционални
Използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Използваме „сесийни“ бисквитки, за да Ви идентифицираме временно. Те се пазят само по време на активната употреба на услугите ни. След излизане от приложението, затваряне на браузъра или мобилното устройство, данните се трият. Използваме бисквитки, за да предоставим опцията „Запомни Ме“, която Ви позволява да използвате нашите услуги без да предоставяте потребителско име и парола. Допълнително е възможно да използваме бисквитки за да съхраняваме различни малки настройки, като избор на езика, позиции на менюта и персонализирано съдържание. Използваме бисквитки и за измерване на маркетинговите ни усилия.
Рекламни
Използваме бисквитки, за да измерваме маркетинг ефективността ни, броене на посещения, както и за проследяването дали дадено електронно писмо е било отворено.