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

Dwumiany - SPOJ

0 głosów
741 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 1,113 wizyt
pytanie zadane 6 marca 2017 w C i C++ przez Andruh Początkujący (390 p.)
+3 głosów
2 odpowiedzi 4,633 wizyt
pytanie zadane 16 stycznia 2016 w C i C++ przez agre Użytkownik (550 p.)
0 głosów
0 odpowiedzi 441 wizyt
pytanie zadane 10 marca 2020 w SPOJ przez wojtek_suchy Mądrala (6,880 p.)

93,741 zapytań

142,676 odpowiedzi

323,294 komentarzy

63,319 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

Twierdza Linux. Bezpieczeństwo dla dociekliwych

Aby uzyskać rabat -10%, użyjcie kodu pasja-linux, wpisując go w specjalne pole w koszyku.

...