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

question-closed Poprawne zaokrąglanie liczby w języku C.

Object Storage Arubacloud
0 głosów
612 wizyt
pytanie zadane 25 stycznia 2021 w C i C++ przez tonn204 Mądrala (7,440 p.)
zamknięte 26 stycznia 2021 przez tonn204

Witam, chcę napisać bardzo prosty program, który najpierw podzieli wybraną liczbę przez inną liczbę, którą wprowadzi użytkownik, a następnie. wyświetli zaokrąglony wynik. Problem na tym, że kiedy, np. dzielę liczbę 14 przez 8 to w kalkulatorze dostaję 1,75, a mój program nie zaokrągla liczby i piszę, że reszta z dzielenia równa jest 6. Jak mam to naprawić?

 

#include <stdio.h>
#include <stdlib.h>

int liczba;
int dzielnik;
int wynik;

int main()
{
    printf("Podaj liczbe: ");
    scanf("%d", &liczba);
    printf("Podaj dzielnik: ");
    scanf("%d", &dzielnik);

    if(liczba%dzielnik >= 5)
    {
        wynik = liczba/dzielnik+1;
        printf("%d\n", wynik);
        printf("To jest reszta z dzielenia: %d\n", liczba%dzielnik);
    }
    else
    {
        printf("%d\n", wynik);
        printf("To jest reszta z dzielenia: %d\n", liczba%dzielnik);
    }

	return 0;
}

 

komentarz zamknięcia: Problem został rozwiązany
komentarz 26 stycznia 2021 przez nanautzin Obywatel (1,510 p.)
Nie za bardzo rozumiem co chcesz osiągnąć
- dokładny wynik dzielenia?
- zaokrąglony wynik dzielenia?
- a może resztę z dzielenia?
komentarz 26 stycznia 2021 przez Oscar Nałogowiec (29,290 p.)
0.75 * 8 = 6 więc wszystko się zgadza.
komentarz 26 stycznia 2021 przez tonn204 Mądrala (7,440 p.)

@nanautzin, chciałbym wiedzieć jaką liczbę uzyskam po przecinku.  Jak np.  w tym przypadku dostanę 75. Chodzi o to, że nie mogę użyć tutaj float tylko musze działać na typach int.

komentarz 26 stycznia 2021 przez wizarddos Nałogowiec (25,930 p.)
Dlaczego nie możesz użyć float?
komentarz 26 stycznia 2021 przez tonn204 Mądrala (7,440 p.)
Bo to ma być program działający na AVR. Wynik, który otrzymuję z  uśrednienia kilku wartości  np. {1, 1, 1, 1, 1, 1, 1 0}  to  0,875 czyli na intach wyjdzie mi 0, a ja chciałbym uzyskać 1 czyli sprawdzić jaką liczbę mam po przecinku  jeżeli jest ona większa lub równa 5 do dodaję do liczby przed przecinkiem 1, a jeżeli liczba po przecinku jest mniejsza od 5 do nic nie dodaję.
komentarz 26 stycznia 2021 przez wizarddos Nałogowiec (25,930 p.)
Ale to wtedy najprawdopodobniej automatycznie zaokrągli w intcie do liczby całkowitej. więc tej liczby po przecinku nie dostaniesz
komentarz 26 stycznia 2021 przez tonn204 Mądrala (7,440 p.)
No właśnie,  a jak mogę mogę tą sprawdzić jaka była ta liczba? Da się w ogóle?
komentarz 26 stycznia 2021 przez wizarddos Nałogowiec (25,930 p.)
przy int. Nie. Musi to być typ zmiennoprzecinkowy (double, float)

3 odpowiedzi

+1 głos
odpowiedź 26 stycznia 2021 przez tonn204 Mądrala (7,440 p.)

Problem został rozwiązany, musiałem tylko chwilkę pokombinować. Tak jak napisał użytkownik @Oscar, 0.75 * 8 = 6

więc liczba, którą dostaję po przecinku to 0,75 = 6/8. I tutaj znowu dostaję wynik zero. Możemy to jednak ominąć mnożąc liczbę 6 razy 10. Wtedy liczba 60/8  = 7.5, więc liczba, którą dostanę to 7.  Jeżeli chciałbym uzyskać większą precyzję po przecinku musiałbym pomnożyć liczbę 6 (resztę z dzielenia) przez większą liczbę czyli powiedzmy, że 100 i wtedy 6*100/8 = 600/8 = 75. Dziękuję wszystkim za pomoc.

Tutaj kod pokazujący jak to działa.

#include <stdio.h>
#include <stdlib.h>

int liczba = 14;
int dzielnik = 8;
int reszta;

int main()
{
    printf("%d", liczba/dzielnik);
    printf(".");
    reszta = liczba%dzielnik;
    printf("%d", reszta*10/dzielnik);

	return 0;


 

Pozdrawiam

0 głosów
odpowiedź 26 stycznia 2021 przez wizarddos Nałogowiec (25,930 p.)

program działa tak... Bo do tego  został napisany. operator modulo % nie wyświetli ci liczby dziesiątek. w tym przypadku 0,75 tylko resztę z dzielenia w tym przypadku 6 a tym bardziej nie zaokrąglonego wyniku  . Jeżeli chcesz zaokrąglić wynik tu użyj np funkcji round. A poza tym to są inty więc tam nigdy nie będziesz mieć liczb zmiennoprzecinkowych. A poza tym po co dodajesz tam tą jedynkę?

komentarz 26 stycznia 2021 przez Nie Wiem Nowicjusz (240 p.)
A propo,czy jest jakaś różnica między round i setprecision?
komentarz 26 stycznia 2021 przez Nie Wiem Nowicjusz (240 p.)
dobra nieważne, jak pomyślałem nad tym to pytanie wyżej było głupie
komentarz 26 stycznia 2021 przez wizarddos Nałogowiec (25,930 p.)

ok. Różnica jest na pewno taka że setprecision jest funkcją z C++ a round z C i round po prostu zaokrągla liczbę a setprecision jak mówi dokumentacja

Sets the decimal precision to be used to format floating-point values on output operations.

Ustawia dokładność dziesiętną, która ma być używana do formatowania wartości zmiennoprzecinkowych w operacjach wyjściowych.

0 głosów
odpowiedź 26 stycznia 2021 przez SzkolnyAdmin Szeryf (86,360 p.)
edycja 26 stycznia 2021 przez SzkolnyAdmin
Skoro liczba ma działać tylko na intach to zrób tak:

1. Podziel liczbę1 przez liczbę2 -> otrzymasz część całkowitą.

2. Znajdź resztę z dzielenia (modulo) liczby1 przez liczbę2.

3. Jeżeli podwojona reszta z dzielenia otrzymana w punkcie 2 jest większa lub równa liczbie2, to zwiększasz część całkowitą otrzymaną w punkcie1 o jeden.

Podobne pytania

0 głosów
1 odpowiedź 523 wizyt
pytanie zadane 28 grudnia 2019 w C# przez mZq Nowicjusz (150 p.)
0 głosów
1 odpowiedź 578 wizyt
0 głosów
1 odpowiedź 577 wizyt
pytanie zadane 6 września 2017 w PHP przez sc4rface Dyskutant (7,710 p.)

92,568 zapytań

141,420 odpowiedzi

319,622 komentarzy

61,954 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!

...