abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 14:00 | Upozornění

    Cloudflare, tj. společnost poskytující "cloudové služby, které zajišťují bezpečnost, výkon a spolehlivost internetových aplikací", má výpadek.

    Ladislav Hagara | Komentářů: 4
    dnes 04:22 | Pozvánky

    Letos se uskuteční již 11. ročník soutěže v programování Kasiopea. Tato soutěž, (primárně) pro středoškoláky, nabízí skvělou příležitost procvičit logické myšlení a dozvědět se něco nového ze světa algoritmů – a to nejen pro zkušené programátory, ale i pro úplné začátečníky. Domácí kolo proběhne online od 22. 11. do 7. 12. 2025 a skládá se z 9 zajímavých úloh různé obtížnosti. Na výběru programovacího jazyka přitom nezáleží – úlohy jsou

    … více »
    SoutezKasiopea | Komentářů: 0
    dnes 04:11 | Nová verze

    Byla vydána nová verze 2.52.0 distribuovaného systému správy verzí Git. Přispělo 94 vývojářů, z toho 33 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 18:00 | Nová verze

    VKD3D-Proton byl vydán ve verzi 3.0. Jedná se fork knihovny vkd3d z projektu Wine pro Proton. Knihovna slouží pro překlad volání Direct3D 12 na Vulkan. V přehledu novinek je vypíchnuta podpora AMD FSR 4 (AMD FidelityFX Super Resolution 4).

    Ladislav Hagara | Komentářů: 0
    včera 03:11 | Nová verze

    Poštovní klient Thunderbird byl vydán v nové verzi 145.0. Podporuje DNS přes HTTPS nebo Microsoft Exchange skrze Exchange Web Services. Ukončena byla podpora 32bitového Thunderbirdu pro Linux.

    Ladislav Hagara | Komentářů: 2
    včera 02:33 | IT novinky

    U příležitosti státního svátku 17. listopadu probíhá na Steamu i GOG.com již šestý ročník Czech & Slovak Games Week aneb týdenní oslava a také slevová akce českých a slovenských počítačových her.

    Ladislav Hagara | Komentářů: 0
    16.11. 19:33 | Nová verze

    Byla vydána nová verze 9.19 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Vypíchnout lze například nový balíček BirdNET-Go, tj. AI řešení pro nepřetržité monitorování a identifikaci ptáků.

    Ladislav Hagara | Komentářů: 0
    16.11. 02:22 | Nová verze

    Byla vydána nová verze 3.38 frameworku Flutter (Wikipedie) pro vývoj mobilních, webových i desktopových aplikací a nová verze 3.10 souvisejícího programovacího jazyka Dart (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    16.11. 01:33 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 28 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    15.11. 16:11 | Nová verze

    Byl vydán Debian 13.2, tj. druhá opravná verze Debianu 13 s kódovým názvem Trixie. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (46%)
     (19%)
     (18%)
     (23%)
     (15%)
     (23%)
     (16%)
     (16%)
    Celkem 367 hlasů
     Komentářů: 16, poslední 12.11. 18:21
    Rozcestník

    Dotaz: C++ problémek s polem

    28.3.2013 10:39 jaguar
    C++ problémek s polem
    Přečteno: 403×

    Dobrý den, jsem samozřejmě v C++ celkem začátečník a teď přišel jeden menší zásek. Popíšu vám můj problém:

    Potřebuju udělat pole, které má nějakou velikost a za určitých okolností se naplňuje hodnotami:

     

    ...
    int id=0;
    int array[500];
    int main(){
    if(podmínka){
    id++;
    array[id]=5;
    }
    }

    Takže teď má array s indexem 1 hodnotu 5. Potřeboval bych udělat, aby kdyby uživatel

    cin >> i;
    if(i==5){
    cout << "Hodnotu 5 má pole s indexem 1";
    }

    Problém je v tom, že nevím jak :) Jak podle hodnoty poznat, k jakému indexu pole je přiřazena? Nevím jestli chápete můj problém, kdyžtak nejasnosti dovysvětlím. Děkuji za případnou pomoc.

    Odpovědi

    28.3.2013 11:18 MadCatX
    Rozbalit Rozbalit vše Re: C++ problémek s polem
    Jedině projít celé pole a zjistit, který prvek má hledanou hodnotu.
    Beda0 avatar 28.3.2013 11:29 Beda0 | skóre: 29
    Rozbalit Rozbalit vše Re: C++ problémek s polem
    Jestli jsem správně pochopil, tak potřebuješ vyhledat v poli podle hodnoty. To je možné udělat ručně - projít všechny prvky pole a porovnávat hodnotu každého prvku s hledanou. Je třeba vyřešit, co se má stát, pokud pole obsahuje víc stejných prvků.

    Druhá možnost je použít find a trochu upravit příklad z manuálu, který najde první výskyt hledaného prvku.
    #include <iostream>     // std::cout
    #include <algorithm>    // std::find
    
    int main () {
      int myints[] = { 10, 20, 30 ,40, 50, 60, 70, 80, 40 };
      int * p;
    
      // pointer to array element:
      p = std::find (myints,myints+9,40);
      if(p != myints+9)
            std::cout << "Found at position " << p-myints << '\n';
      else
            std::cout << "Not found" << '\n';
    
      return 0;
    }
    Ukázky kódu se vkládají do tagů <pre> a <code>, aby byly lépe čitelné.
    29.3.2013 16:57 jaguar
    Rozbalit Rozbalit vše Re: C++ problémek s polem
    Díky, tohle je super, akorát to samé potřebuju udělat i s char arrayem a s ním to nefunguje, nevím jestli by vůbec mělo. Zkoušel jsem
    std::binary_search
    ale opět bez výsledku, tak buď dělám něco špatně, nebo se to má dělat ještě jinak.
    29.3.2013 17:19 Zadejte vaše jméno
    Rozbalit Rozbalit vše Re: C++ problémek s polem
    memmem() bude fungovat pro vsechno :P
    29.3.2013 19:24 jaguar
    Rozbalit Rozbalit vše Re: C++ problémek s polem
    Tak s charama jsem to nakonec někde našel a vyřešil takto:
    
    char findf(char arr[], int arrSize, char seek){
    
    	for(int i=0; i < arrSize; i++){
    		if(arr[i] == seek) return i;
    		}
    	return -1;
    
    }
    
    ...
    
    int x = findf(array, arraySize, char)
    
    
    28.3.2013 12:29 jekub
    Rozbalit Rozbalit vše Re: C++ problémek s polem
    c++, místo int array[] std::vector<int>. Pro vyhledání použít find (sekvenční), nebo std::map
    29.3.2013 20:55 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: C++ problémek s polem
    Správně, nicméně já mám taky rád C+ :-).
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.