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

Dwumiany - SPOJ

Object Storage Arubacloud
0 głosów
437 wizyt
pytanie zadane 8 sierpnia 2018 w SPOJ przez Filip Stolarczyk Nowicjusz (200 p.)

Witam. Proszę o pomoc, ponieważ od dłuższego czasu nie potrafię sobie wyjaśnić, dlaczego dla niektórych kombinacji wynik to 0 (patrz np. 90 i 89). Może ktoś wskazać problem? :/

https://pl.spoj.com/problems/BINOMS/

#include <iostream>

using namespace std;

int main()
{
    int t;
    cin>>t;

    for(int i=0; i<t; i++)
    {
        int n, k;
        unsigned long long wynik;
        cin>>n>>k;

        if (k==1)
            cout<<n<<endl;
        else if (k==0)
            cout<<"1"<<endl;
        else
        {
            wynik=n;

            for (int j=1; -j>=-k+1; j++)
            {
                wynik=wynik*(n-j)/(j+1);
            }
            cout<<wynik<<endl;

        }
    }
    return 0;
}

 

1 odpowiedź

0 głosów
odpowiedź 8 sierpnia 2018 przez k222 Nałogowiec (30,150 p.)
wybrane 10 sierpnia 2018 przez Filip Stolarczyk
 
Najlepsza
Wydaje mi się, że przy dużych bliskich sobie liczbach po prostu zmienna wynik może przekraczać wartość maksymalną typu unsigned long long, mimo że wynik nie będzie duży, bo w 26 linijce na początku mnożysz przez duże liczby (n-j)  a dzielisz przez małe (j+1) i rozwiązać ten problem możesz w ten sposób, że dla dużych k zamiast wyznaczać ilość k elementowych podzbiorów wyznacz ilość n-k elementowych podzbiorów (jeśli n-k < k) i przy okazji pomyśl, dlaczego te dwie liczby są sobie równe.

Podobne pytania

0 głosów
2 odpowiedzi 472 wizyt
pytanie zadane 6 marca 2017 w C i C++ przez Andruh Początkujący (390 p.)
+3 głosów
2 odpowiedzi 4,215 wizyt
pytanie zadane 16 stycznia 2016 w C i C++ przez agre Użytkownik (550 p.)
0 głosów
0 odpowiedzi 243 wizyt
pytanie zadane 10 marca 2020 w SPOJ przez wojtek_suchy Mądrala (6,880 p.)

92,572 zapytań

141,422 odpowiedzi

319,643 komentarzy

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

...