Loading...
i.iliev90 avatar i.iliev90 0 Точки

Какво означава 7u ?

using System;
class BitsExchange
{
    static void Main()
     {
      Console.Write("Enter your number: ");
       long NumberG = long.Parse(Console.ReadLine());
      Console.WriteLine(Convert.ToString(NumberG, 2).PadLeft(32, '0'));

       NumberG = ((~(7u << 24 | 7u << 3)) & NumberG) | (((NumberG & (7u << 3)) << 21) | ((NumberG & (7u                           << 24)) >> 21));
      Console.WriteLine(NumberG);
      Console.WriteLine(Convert.ToString(NumberG, 2).PadLeft(32, '0'));

     }

}

 

Колеги, някой може ли да ми обясни каква роля играе това 7u в дадения код ?

Тагове:
0
Programming Basics
Kosta avatar Kosta 35 Точки

В случая 'u' е суфикс, обозначаващ, че числото пред него - в случая 7 - е от тип uint (unsigned integer). Представено двоично изглежда така :
0000 0000 0000 0000 0000 0000 0000 0111
А преместено наляво с 24 позиции (7u << 24) :
0000 0111 0000 0000 0000 0000 0000 0000

2
i.iliev90 avatar i.iliev90 0 Точки

Това за суфикса е ясно, но ме интересува какво точно прави и защо като го сменя с друго (пример: 3u,4u,5u и т.н.) се променя. 

0
Kosta avatar Kosta 35 Точки

Седмицата в този случай се използва като маска, защото представена двоично, трите и най-младши бита са единици, което помага при поставената задача. Като гледам решението предполагам , че трябва да се сменят местата на битове от позиции 4,5,6 с  тези на позиции 25,26,27 ( броейки от 0 ) или нещо подобно, не ми се решават oneliner-и.
Ако използваш 3u, например, получаваш двоично за маска:
0000 0000 0000 0000 0000 0000 0000 0011
и съответно побитовата аритметика ще даде различен резултат

0
ViValDam avatar ViValDam 15 Точки

7

ами специално за побитовата част

NumberG = ((~(7u << 24 | 7u << 3)) & NumberG) | (((NumberG & (7u << 3)) << 21) | ((NumberG & (7u << 24)) >> 21));

7 десетична    =  0000 0000 0000 0000 0000 0000 0000 0111 ( за uint , който е 32 бита без знак)

 (7u << 24)  =   0000 0001 1100 0000 0000 0000 0000 0000

 ~(7u << 24) =  1111 1110 1111 1111 1111 1111 1111 1111

 7u << 3        =  0000 0000 0000 0000 0000 0000 0011 1000

 

 ~(7u << 24 | 7u << 3)    =>  (1111 1110 1111 1111 1111 1111 1111 1111 )        

                                           |                                    

                                            (  0000 0000 0000 0000 0000 0000 0011 1000 )

                                          =

                                               1111 1110 1111 1111 1111 1111 1111 1111

                                          &&

                                              Number G - които се прочита от конзолота и деклариран  от тип  long , който е 64 битов , не знам защо ???

 

и така нататъка 

 

Но ако това е нашата задача от домашното е пълна глупост ! Има специална тема с много решения за тази задача и обяснения към побитовете операции , можеш да си си прочетеш и от учебника по-подробно илинка към учебника е тук отдолу на форума  в синята част

 

2
Можем ли да използваме бисквитки?
Ние използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Можете да се съгласите с всички или част от тях.
Назад
Функционални
Използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Използваме „сесийни“ бисквитки, за да Ви идентифицираме временно. Те се пазят само по време на активната употреба на услугите ни. След излизане от приложението, затваряне на браузъра или мобилното устройство, данните се трият. Използваме бисквитки, за да предоставим опцията „Запомни Ме“, която Ви позволява да използвате нашите услуги без да предоставяте потребителско име и парола. Допълнително е възможно да използваме бисквитки за да съхраняваме различни малки настройки, като избор на езика, позиции на менюта и персонализирано съдържание. Използваме бисквитки и за измерване на маркетинговите ни усилия.
Рекламни
Използваме бисквитки, за да измерваме маркетинг ефективността ни, броене на посещения, както и за проследяването дали дадено електронно писмо е било отворено.