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

Zamiana z dziesietnego na binarne

VPS Starter Arubacloud
0 głosów
368 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ź 411 wizyt
0 głosów
2 odpowiedzi 301 wizyt
pytanie zadane 12 listopada 2018 w C i C++ przez Programmingc100 Bywalec (2,620 p.)
–4 głosów
2 odpowiedzi 180 wizyt
pytanie zadane 4 stycznia 2016 w C i C++ przez Ciri Gaduła (3,380 p.)

92,454 zapytań

141,262 odpowiedzi

319,099 komentarzy

61,854 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...