eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.programmingHasz dla permutacji › Re: Hasz dla permutacji
  • Path: news-archive.icm.edu.pl!news.icm.edu.pl!news.man.lodz.pl!newsfeed.pionier.net.p
    l!news.samoylyk.net!aioe.org!peer03.ams4!peer.am4.highwinds-media.com!news.high
    winds-media.com!newsfeed.neostrada.pl!unt-exc-01.news.neostrada.pl!unt-spo-a-02
    .news.neostrada.pl!news.neostrada.pl.POSTED!not-for-mail
    Subject: Re: Hasz dla permutacji
    Newsgroups: pl.comp.programming
    References: <5f43602a$0$525$65785112@news.neostrada.pl>
    <5f4375ff$0$514$65785112@news.neostrada.pl>
    <20200824102034.5b84b398@mateusz>
    <5f43a516$0$17360$65785112@news.neostrada.pl>
    <20200824134841.158f03e5@mateusz>
    From: Borneq <b...@a...hidden.pl>
    Date: Mon, 24 Aug 2020 13:52:37 +0200
    User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101
    Thunderbird/68.10.0
    MIME-Version: 1.0
    In-Reply-To: <20200824134841.158f03e5@mateusz>
    Content-Type: text/plain; charset=utf-8; format=flowed
    Content-Language: en-US
    Content-Transfer-Encoding: 8bit
    Lines: 52
    Message-ID: <5f43aa05$0$17363$65785112@news.neostrada.pl>
    Organization: Telekomunikacja Polska
    NNTP-Posting-Host: 37.47.15.226
    X-Trace: 1598269958 unt-rea-a-01.news.neostrada.pl 17363 37.47.15.226:12627
    X-Complaints-To: a...@n...neostrada.pl
    X-Received-Bytes: 2541
    X-Received-Body-CRC: 3002670772
    Xref: news-archive.icm.edu.pl pl.comp.programming:215121
    [ ukryj nagłówki ]

    On 8/24/20 1:48 PM, Mateusz Viste wrote:
    > 2020-08-24 o 13:31 +0200, Borneq napisał:
    >> On 8/24/20 10:20 AM, Mateusz Viste wrote:
    >>> Rób dwie operacje: xor oraz shift jednego bitu... Tak działa BSD
    >>> sum. Zalety takie, że jeszt bardzo szybki oraz wrażliwy na inwersję
    >>> wartości. Szerokość takiego hashu sobie możesz dopasować sam,
    >>> wystarczy użyć innego clampingu.
    >>>
    >>> 3 lata temu popełniłem tego implementację:
    >>> https://sourceforge.net/p/bsum/code/HEAD/tree/trunk/
    bsum.asm
    >>
    >> Zastanwiam się, bo taki hasz ma okreśłoną "pojemność" po 32 takich
    >> przeunięciach wcześniejsze wartości nie będą miały żadnego wpływu na
    >> sumę.
    >
    > Mój błąd, z rozpędu i przyzwyczajenia napisałem "shift", a powinno być
    > "rotate". W kodzie który podlinkowałem zobaczysz "ror".
    >
    > Mateusz
    >

    No tak, ale jak potem zamienić jeden bajt na inny?
    Z mnożeniem świetnie wychodzi, kod w c++

    #include <iostream>
    #include <vector>

    using namespace std;

    int sum1 (vector<int8_t> &v) {
    int res = 1;
    for (int i=0; i<v.size();i++){
    res += v[i]*(i+1);
    }
    return res;
    }


    int main() {
    vector<int8_t> v;
    v.clear();
    v.push_back(1);
    v.push_back(3);
    v.push_back(32);
    v.push_back(2);
    int sum = sum1(v);
    std::cout << sum << std::endl;
    v[2]=127;
    int fastsum = sum + 3*(127-32);
    std::cout << fastsum << " " << sum1(v) << std::endl;
    return 0;
    }

Podziel się

Poleć ten post znajomemu poleć

Wydrukuj ten post drukuj


Następne wpisy z tego wątku

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: