eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingDokładny podział integera na k jednakowych integerów › Re: Dokładny podział integera na k jednakowych integerów
  • Path: news-archive.icm.edu.pl!news.icm.edu.pl!newsfeed2.atman.pl!newsfeed.atman.pl!.P
    OSTED!not-for-mail
    From: Borneq <b...@a...hidden.pl>
    Newsgroups: pl.comp.programming
    Subject: Re: Dokładny podział integera na k jednakowych integerów
    Date: Tue, 30 Jan 2018 19:35:49 +0100
    Organization: ATMAN - ATM S.A.
    Lines: 38
    Message-ID: <p4qdu5$b6v$1@node2.news.atman.pl>
    References: <p4qakp$82b$1@node2.news.atman.pl> <p4qbgf$8k2$2@node2.news.atman.pl>
    <p4qbk8$8k2$3@node2.news.atman.pl>
    NNTP-Posting-Host: public-gprs351922.centertel.pl
    Mime-Version: 1.0
    Content-Type: text/plain; charset=utf-8; format=flowed
    Content-Transfer-Encoding: 8bit
    X-Trace: node2.news.atman.pl 1517337349 11487 37.47.5.243 (30 Jan 2018 18:35:49 GMT)
    X-Complaints-To: u...@a...pl
    NNTP-Posting-Date: Tue, 30 Jan 2018 18:35:49 +0000 (UTC)
    User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101
    Thunderbird/52.5.2
    In-Reply-To: <p4qbk8$8k2$3@node2.news.atman.pl>
    Content-Language: pl
    Xref: news-archive.icm.edu.pl pl.comp.programming:212259
    [ ukryj nagłówki ]

    W dniu 30.01.2018 o 18:56, Borneq pisze:
    >> ceil zamiast floor tutaj pomaga ale to niezbyt eleganckie rozwiązanie,
    >> trzeba nie używać interval ale wymiernego n/k, jak?
    > ceil - nie!

    Rozwiązanie:
    Chodzi o przydział wątków, więc mogę "po chamsku" wstawić ostatnią wartość:
    vector<uint32_t> getRanges(int n, int k, int mintask)
    {
    double interval = double(n) / k;
    if (interval<mintask)
    {
    k = n / mintask;
    interval = double(n) / k;
    }
    vector<uint32_t> result;
    result.push_back(0);
    uint32_t intPartPos, fracPartPos;
    uint32_t intPartDelta, fracPartDelta, oldFrac;
    intPartPos = 0; fracPartPos = 0;
    intPartDelta = (uint32_t)floor(interval);
    fracPartDelta = (uint32_t)floor((interval - intPartDelta) * 65536 * 65536);
    for (int i = 0; i<k - 1; i++)
    {
    intPartPos += intPartDelta;
    oldFrac = fracPartPos;
    fracPartPos += fracPartDelta;
    if (oldFrac > fracPartPos) // when LongWord overflow
    intPartPos++;
    result.push_back(intPartPos);
    }
    result.push_back(n);
    return result;
    }


    mintask to liczba , ile minimalnie obiektami może zająć się wątek, aby
    nie było nagle 1 czy 0.

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj

Najnowsze wątki z tej grupy


Najnowsze wątki

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: