• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Zamiana z dziesietnego na binarne

Object Storage Arubacloud
0 głosów
382 wizyt
pytanie zadane 26 listopada 2018 w C i C++ przez Padoski Użytkownik (990 p.)

Chcialem stworzyc program ktory zamienia liczby z systemu dziesietnego na binarne. Stworzylem cos takiego:

Nie widzialem jak sprawdzic jak dlugie będą reszty z modulo2 więc stworzylem zmienną pomocniczną liczącą ile razy wykona się pętla. Czy mozna zrobic to w inny sposób ? W programie nie działa odwracanie tego ciągu reszt, aby wypisac to w postaci binarnej. Dlaczego ?

#include <iostream>

using namespace std;

void zamianaNaDziesietny(int);

int main()
{
    int liczba;
    cout << "Podaj dowolna liczbe w systemie dziesietnym:";
    cin>>liczba;
	zamianaNaDziesietny(liczba);
}
void zamianaNaDziesietny(int x)
{
    int licznik=0;
	int reszty[100];
    int i=0;
	while(x>0)
    {
        i++;
        reszty[i]=x%2;
        x=x/2;
        cout<<reszty[i];
        licznik++;
    }
    cout<<endl;
    cout<<licznik<<endl;

    for(int i=licznik-1; i>=0; i--)
    {
        cout<<reszty[i];
    }


}

 

1 odpowiedź

0 głosów
odpowiedź 26 listopada 2018 przez kamerek Obywatel (1,260 p.)

Możesz dynamicznie alokować wielkość tablicy reszty[] na podstawie wielkości wprowadzonej liczby. Zobacz jak to można zrobić:

void zamianaNaDziesietny(int x)
{
    int licznik=0;
    //int reszty[100];
    int *reszty;  // deklaracja wskaznika na pierwszy element tablicy
    int rozmiar;  // rozmiar tablicy

    if (x==0 || x==1) rozmiar=1;
    else if (x==2 || x==3) rozmiar=2;
    else if (x>=4 && x<8) rozmiar=3;
    else if (x>=8 && x<16) rozmiar=4;
    else if (x>=16 && x<32) rozmiar=5;
    else if (x>=32 && x<64) rozmiar=6;
     // i kolejne warunki w podobny sposob

    reszty = new int[rozmiar];  //dynamiczna alokacja tablicy reszty[]

    int i=0;
    while(x>0)
    {
        i++;
        reszty[i]=x%2;
        x=x/2;
        cout<<reszty[i];
        licznik++;
    }
    cout<<endl;
    cout<<licznik<<endl;

    for(int i=licznik; i>0; i--)
    {
        cout<<reszty[i];
    }

    delete []reszty;  //usunięcie tablicy reszty[]

}

Odwracanie reszt w twoim programie działa - podajesz jedynie niewłaściwe warunki do wykonania pętli for.

Sprawdź działanie programu dla takiej pętli for:

for(int i=licznik; i>0; i--)
    {
        cout<<reszty[i];
    }

 

komentarz 26 listopada 2018 przez Padoski Użytkownik (990 p.)
edycja 26 listopada 2018 przez Padoski
Dzieki za pomoc, :)

Podobne pytania

0 głosów
1 odpowiedź 421 wizyt
0 głosów
2 odpowiedzi 306 wizyt
pytanie zadane 12 listopada 2018 w C i C++ przez Programmingc100 Bywalec (2,620 p.)
–4 głosów
2 odpowiedzi 182 wizyt
pytanie zadane 4 stycznia 2016 w C i C++ przez Ciri Gaduła (3,380 p.)

92,551 zapytań

141,397 odpowiedzi

319,527 komentarzy

61,936 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...