Contact și feedback

Nu obții 100 de puncte sau ai nelămuriri în privința problemelor? Scrie-mi pe Instagram.


Ai găsit o greșeală, vrei să raportezi un utilizator sau vrei să comunici altceva? Folosește formularul de contact.


Vrei să ne transmiți o părere despre platformă? Folosește formularul de feedback.

Shortcuturi

Folosește următoarele shortcuturi pentru a naviga mai ușor pe platformă.

Generale

Meniu shortcuturi?
Căutare probleme sau utilizatori/
Navigare printre rezultatele căutării↑, ↓
Meniu de contact și feedbackCTRL + Shift + F
Ieșire din meniuriEsc

Editor probleme

Setări editorCTRL + Shift + S
Schimbare stil editorCTRL + Shift + E
Șabloane de codCTRL + Shift + 1/2/3
Golire editorCTRL + Shift + 4

Cel mai puțin semnificativ bit în C++

Dându-se un număr natural n, să se găsească bitul de 1 cel mai puțin semnificativ al lui n.

Exemplu. Pentru n = 10, reperezentarea sa binară este 1010, iar cel mai puțin semnificativ bit de 1 este cel de pe poziția 1:

https://i.ibb.co/chB313n/image.png

Explicarea algoritmului

Vom parcurge biții numărului pe rând, de la poziția 0 până când întrecem valoarea n. Când întâlnim un bit de 1, ne oprim și afișăm poziția.

Cum parcurgem biții unui număr?

Vom genera puterile de 2: 20 = 1, 21 = 2, 22 = 4, …, până când întrecem valoarea n. Știm că o putere 2k are în reprezentarea sa binară k cifre de 0, după care o cifră de 1:

22 =  4 =    10
24 = 16 = 10000
20 =  1 =     1

Cu această observație, dacă facem AND între 2^i și n, putem afla dacă al i-lea bit din număr este 1 sau 0.

Implementare C++

Iată codul în C++:

#include <iostream>

using namespace std;

int main()
{
    //Declarăm și citim numărul nostru, n
    int n;
    cin >> n;

    //Determinăm cel mai puțin semnificativ bit de 1
    int i = 0, j = 1; //i este poziția curentă (0, 1, 2, …), j = 2^i (1, 2, 4, …)
    while(j <= n) {
        if(j & n) { //Verificăm dacă al i-lea bit este 1
            cout << i;
            break;
        }
        i++; //Creștem puterea
        j = j * 2;
    }
    return 0;
}

Alte resurse și bibliografie

Cuprinsul lecției

Se încarcă…

Citește și

Ce este o variabilă unsigned în C++?Oglinditul recursiv al unui număr în C++Verificare dacă un număr este palindrom în C++Inversarea unui șir de caractere în C++Transformarea unei litere mici în literă mare în C++Al N-lea termen dintr-o progresie aritmeticăCiurul lui Eratostene în C++Matrice în C++. Declararea și parcurgerea tablourilor bidimensionaleMaximul și minimul a trei valori în C++CMMDC recursiv a două numere naturale în C++Citirea și afișarea matricelor în C++Cifra maximă și minimă a unui număr în C++Cum să calculezi instant 2 la puterea N în C++Indicatorul lui Euler în C++Divide et Impera (metodă de programare C++)Prima cifră a unui număr în C++Funcții predefinite în C++ (matematice, șiruri de caractere)Cifra maximă a unui număr recursiv în C++Codul ASCII (tabel complet)Oglinditul unui număr în C++Ce înseamnă variabilă globală și locală în C++?Tipul struct în C++. Ce sunt structurile de date neomogeneComentarii în C++Verifică dacă un caracter este cifră în C++Suma numerelor naturale dintr-un interval dat în C++Numărul de cifre ale factorialului unui numărInstrucțiunea do while (structuri repetitive)Suma divizorilor numerelor de la 1 la N (Folosind ciurul lui Eratostene)Combinatorică în C++: permutări, aranjamente, combinări și alteleInterclasarea a doi vectori în C++Valoarea absolută (modulul) unui număr în C++Cel mai mic număr cu suma cifrelor N în C++Aflarea sumei primelor N sume GaussMatrice pătratice în C++. Diagonala principală și secundarăRecursivitate în C++Verifică dacă un caracter este literă în C++Structuri repetitive (while, do while, for, etc)Numărul de divizori primi ai unui număr în C++Tipuri de date în C++: numere întregi, reale, caractere și alteleDe ce cer unele probleme răspunsul modulo 666013 sau modulo 1.000.000.007?Cel mai semnificativ bit în C++Aplicații cu ciurul lui Eratostene în C++: suma divizorilor, numărul divizorilorInstrucțiunea de decizie în C++: if, else, switch, caseRidicarea la putere în timp logaritmic în C++. Exponențiere rapidăNumărul permutărilor în C++ (formula permutărilor)Cea mai lungă secvență de elemente crescătoare în C++Matrice Fibonacci - al n-lea termen Fibonacci în timp logaritmicCifrele unui număr. Prelucrarea cifrelor unui număr în C++Generarea șirului Fibonacci generalizat în C++Numărul de apariții al unui număr într-un vector în C++Suma divizorilor unui număr în C++Numărul de divizori al numerelor de la 1 la N (Folosind ciurul lui Eratostene)Câte numere naturale sunt într-un interval dat? (C++)Complexitatea unui algoritm (timp și spațiu) în C++Aria unui triunghi folosind coordonatele acestora în C++Numărul minim de peroane pentru o gară în C++Indicatorul lui Euler al numerelor de la 1 la N (Folosind ciurul lui Eratostene)Verifică dacă un număr este par sau impar fără modulo în C++Vectorii în C++: citire și afișareCel mai mic/mare divizor prim al numerelor de la 1 la N (Folosind ciurul lui Eratostene)Suma elementelor unui vector recursiv în C++Mediana unui șir de valori în C++Ce este o funcție void în C++?Afișarea elementelor unui vector recursiv în C++Ce înseamnă endl în C++?Citește un șir de caractere cu spații în C++Radicalul unui număr în C++ (rădăcina pătrată)Verificarea unui an bisect în C++Transformarea unui număr din baza 2 în baza 10 în C++Algoritm recursiv pentru căutare binară (clasa a X-a)Numărul combinărilor în C++ (formula combinărilor)Transformarea unui număr din baza 10 în baza 2 în C++Șirul lui Fibonacci în C++Verificare număr prim în C++ (Clasa a IX-a)Suma 1 + 2 + 3 + ... + N în C++Sortare crescătoare recursivă în C++ - Merge sort și Bubble sortInterschimbarea a două variabile în C++ (3 metode)Instrucțiunea for (structuri repetitive)Instrucțiunea continue (structuri repetitive)Verifică dacă o literă este vocală în C++Șiruri de caractere în C++. Tot ce trebuie să știiVerifică dacă un număr aparține șirului Fibonacci în C++Pointer în C++. Variabile de tipul char * (char steluță)Numere triunghiulare. Verificarea unui număr triunghiularMaximul și minimul a n valori în C++Verifică dacă un număr dat este o putere de 2 în C++Instrucțiunea break (structuri repetitive)Transformarea unei litere mari în literă mică în C++Află secolul unui an citit de la tastatură în C++Do while vs while în C++ - Care e diferența?Inversarea unui vector în C++Funcții în C++. Ce sunt subprogrameleTutorial instalare CodeBlocks (ușor) - Introducere în informatică C++Al N-lea termen dintr-o progresie geometricăCăutare binară în C++Cel mai mare divizor comun (CMMDC) a două numere în C++Verifică dacă trei puncte sunt coliniare C++Instrucțiunea while (structuri repetitive)Distanța dintre două puncte în C++Factorialul unui număr în C++Calculul combinărilor de n luate câte k (nCk) în C++Copiuțe: Cifrele unui numărCum să citești și să afișezi în fișiere în C++Vectorii în C++: declarare și parcurgereOperații cu numere mari în C++ - Toate funcțiile explicateMateria pentru olimpiada de informatică - tot ce trebuie să știiCMMMC a două numere în C++ (cel mai mic multiplu comun)Cel mai frecvent element dintr-un șir în C++Vectori de frecvență (de apariții) în C++Numărul aranjamentelor în C++ (formula aranjamentelor)Al N-lea termen Fibonacci în C++Verifică dacă o literă este mică sau mare în C++Cifra de control a unui numărBordarea unei matrice în C++Numărul de divizori al unui număr în C++Verifică dacă un bit de pe o anumită poziție este 1 sau 0 în C++Verificare dacă șir de caractere este palindrom în C++Maximul și minimul unui vector în C++Afișarea divizorilor primi ai unui număr în C++Aria și circumferința unui cerc în C++Maximul și minimul a două valori în C++Cum să afișezi partea întreagă a unui număr real în C++Rădăcina cubică a unui număr în C++ (cube root)Cel mai puțin semnificativ bit în C++

© Drepturi de autor

Echipa InfoAs își rezervă drepturile de autor pentru conținutul acestei pagini. Copierea conținutului fără acordul scris expres al InfoAs reprezintă o încălcare a Legii 8/1996 și va fi tratată ca atare.

Trimite lecția

Toată lecția

Doar videoclipul pe YouTube

Informatica devine ușoară cu InfoAs

Intră în cont