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

Szukanie duplikatów

Object Storage Arubacloud
0 głosów
499 wizyt
pytanie zadane 11 lipca 2018 w C i C++ przez awezik Nowicjusz (140 p.)
Czy jest możliwość napisania kodu który umożliwi wyszukanie duplikatów w notatniku?
Mam generator liczb losowych który wysyła losowe liczby do notatnika.. szansa jest że cyfry będą takie same. Jest jakiś program bądź kod który to "prześwietli" i sprawdzi czy owych duplikatów nie ma?
komentarz 11 lipca 2018 przez Secrus Nałogowiec (32,880 p.)
Generator liczb to twój program? Bo jeśli tak, to pomyśl czy nie lepiej dodać opcję losowania bez powtórzeń zamiast pisać drugi program do tego

1 odpowiedź

+1 głos
odpowiedź 11 lipca 2018 przez Bondrusiek Maniak (61,370 p.)

Witam,

możesz wykorzystać funkcje std::unique aby pozbyć się duplikatów z kontenera. Przykładowy kod

#include <iostream>
#include <algorithm>
#include <vector>
#include <string>
#include <cctype>

int main()
{
    // remove duplicate elements (normal use)
    std::vector<int> v{1,2,3,1,2,3,3,4,5,4,5,6,7};
    std::sort(v.begin(), v.end()); // 1 1 2 2 3 3 3 4 4 5 5 6 7
    auto last = std::unique(v.begin(), v.end());
    // v now holds {1 2 3 4 5 6 7 x x x x x x}, where 'x' is indeterminate
    v.erase(last, v.end());
    for (int i : v)
      std::cout << i << " ";
    std::cout << "\n";

    // remove consecutive spaces
    std::string s = "wanna go    to      space?";
    auto end = std::unique(s.begin(), s.end(), [](char l, char r){
        return std::isspace(l) && std::isspace(r) && l == r;
    });
    // s now holds "wanna go to space?xxxxxxxx", where 'x' is indeterminate
    std::cout << std::string(s.begin(), end) << '\n';
}

Więcej info

https://en.cppreference.com/w/cpp/algorithm/unique

komentarz 11 lipca 2018 przez awezik Nowicjusz (140 p.)
A tak trochę jaśniej. Narazie wiem że odpalać to w c++ ale gdzie dać ścieżkę do pliku czy coś?
komentarz 11 lipca 2018 przez Bondrusiek Maniak (61,370 p.)
...
int main()
{
    // remove duplicate elements (normal use)
    std::vector<int> v{};
    std::string line;
    std::ifstream myfile("text.txt");//ścieżka do pliku z liczbami 
    if( myfile.is_open() )
    {
        while( std::getline(myfile, line)){
            v.push_back( std::stoi(line) ); // std::stoi() zamienia string na int
        }
        myfile.close();
    }
...

 

komentarz 11 lipca 2018 przez awezik Nowicjusz (140 p.)
To co teraz wysłałeś mam wkleić do c++, dodać ścieżkę i odpalać?
komentarz 11 lipca 2018 przez Bondrusiek Maniak (61,370 p.)
tak

Podobne pytania

0 głosów
2 odpowiedzi 144 wizyt
pytanie zadane 25 marca 2016 w Java przez azybad Mądrala (5,500 p.)
0 głosów
0 odpowiedzi 178 wizyt
pytanie zadane 2 września 2023 w Python przez benek111 Początkujący (260 p.)
0 głosów
2 odpowiedzi 182 wizyt
pytanie zadane 13 sierpnia 2023 w C i C++ przez Janchess Początkujący (480 p.)

92,579 zapytań

141,432 odpowiedzi

319,664 komentarzy

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

...