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 13:22 | Komunita

    Ubuntu 25.10 má nově balíčky sestavené také pro úroveň mikroarchitektury x86-64-v3 (amd64v3).

    Ladislav Hagara | Komentářů: 2
    dnes 01:22 | Nová verze

    Byla vydána verze 1.91.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    dnes 00:11 | IT novinky

    Ministerstvo průmyslu a obchodu vyhlásilo druhou veřejnou soutěž v programu TWIST, který podporuje výzkum, vývoj a využití umělé inteligence v podnikání. Firmy mohou získat až 30 milionů korun na jeden projekt zaměřený na nové produkty či inovaci podnikových procesů. Návrhy projektů lze podávat od 31. října do 17. prosince 2025. Celková alokace výzvy činí 800 milionů korun.

    Ladislav Hagara | Komentářů: 3
    včera 23:44 | Komunita

    Google v srpnu oznámil, že na „certifikovaných“ zařízeních s Androidem omezí instalaci aplikací (včetně „sideloadingu“) tak, že bude vyžadovat, aby aplikace byly podepsány centrálně registrovanými vývojáři s ověřenou identitou. Iniciativa Keep Android Open se to snaží zvrátit. Podepsat lze otevřený dopis adresovaný Googlu nebo petici na Change.org.

    Ladislav Hagara | Komentářů: 0
    včera 15:22 | Nová verze

    Byla vydána nová verze 18 integrovaného vývojového prostředí (IDE) Qt Creator. S podporou Development Containers. Podrobný přehled novinek v changelogu.

    Ladislav Hagara | Komentářů: 1
    včera 12:55 | Nová verze

    Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 2.0. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).

    Ladislav Hagara | Komentářů: 1
    včera 02:55 | Nová verze

    Google Chrome 142 byl prohlášen za stabilní. Nejnovější stabilní verze 142.0.7444.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 20 bezpečnostních chyb. Za nejvážnější z nich bylo vyplaceno 50 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    včera 01:22 | IT novinky Ladislav Hagara | Komentářů: 0
    29.10. 17:00 | Upozornění

    Národní identitní autorita, tedy NIA ID, MeG a eOP jsou nedostupné. Na nápravě se pracuje [𝕏].

    Ladislav Hagara | Komentářů: 11
    29.10. 16:44 | IT novinky

    Americký výrobce čipů Nvidia se stal první firmou na světě, jejíž tržní hodnota dosáhla pěti bilionů USD (104,5 bilionu Kč). Nvidia stojí v čele světového trhu s čipy pro umělou inteligenci (AI) a výrazně těží z prudkého růstu zájmu o tuto technologii. Nvidia již byla první firmou, která překonala hranici čtyř bilionů USD, a to letos v červenci.

    Ladislav Hagara | Komentářů: 6
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (19%)
     (19%)
     (22%)
     (17%)
     (21%)
     (17%)
     (18%)
    Celkem 290 hlasů
     Komentářů: 14, poslední 14.10. 09:04
    Rozcestník

    Administrace komentářů

    Jste na stránce určené pro řešení chyb a problémů týkajících se diskusí a komentářů. Můžete zde našim administrátorům reportovat špatně zařazenou či duplicitní diskusi, vulgární či osočující příspěvek a podobně. Děkujeme vám za vaši pomoc, více očí více vidí, společně můžeme udržet vysokou kvalitu AbcLinuxu.cz.

    Příspěvek
    26.2.2019 01:59 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Pomůžete mi prosím se seřazením položek v array?

    Ještě bych dodal, jen tak z prdele, co s tím, kdyby to muselo být efektivní a kdyby to náhodou nesmělo využívat řídká pole v Bashi. #firstworldproblems #becausewecan

    Napřed si vyrobíme mergesort na integery:

    mergesort() {
      local -n -r input_reference="$1"
      local -n output_reference="$2"
      local -r -i size="${#input_reference[@]}"
      local -a -i merge runs indices
      local -i index previous merged_idx \
               run_a_idx run_a_stop \
               run_b_idx run_b_stop
    
      output_reference=("${input_reference[@]}")
      if ((size == 0)); then return; fi
    
      previous=output_reference[0]
      runs=(0)
      for ((index = 0;;)) do
        for ((++index;; ++index)); do
          if ((index >= size)); then break 2; fi
          if ((output_reference[index] < previous)); then break; fi
          previous=output_reference[index]
        done
        previous=output_reference[index]
        runs+=(index)
      done
      runs+=(size)
    
      while (("${#runs[@]}" > 2)); do
        indices=("${!runs[@]}")
        merge=("${output_reference[@]}")
        for ((index = 0; index < "${#indices[@]}" - 2; index += 2)); do
          merged_idx=runs[indices[index]]
          run_a_idx=merged_idx
          previous=indices[$((index + 1))]
          run_a_stop=runs[previous]
          run_b_idx=runs[previous]
          run_b_stop=runs[indices[$((index + 2))]]
          unset runs[previous]
          while ((run_a_idx < run_a_stop && run_b_idx < run_b_stop)); do
            if ((merge[run_a_idx] < merge[run_b_idx])); then
              output_reference[merged_idx++]=merge[run_a_idx++]
            else
              output_reference[merged_idx++]=merge[run_b_idx++]
            fi
          done
          while ((run_a_idx < run_a_stop)); do
            output_reference[merged_idx++]=merge[run_a_idx++]
          done
          while ((run_b_idx < run_b_stop)); do
            output_reference[merged_idx++]=merge[run_b_idx++]
          done
        done
      done
    }
    
    A pak na to klidně napasujeme třídění těch cest k souborům. Míle a míle se táhnou těch cest. Tady už se ale řídká pole používají, ježto se mi to nechtělo řešit jinak, a v tom je ošklivost: Výraz "${!input_map[@]}" dá ty indexy už setříděné, takže následující mergesort krok je úplně k hovnu. Ale to nevadí, když máme ten mergesort tak úžasně efektivní, on se s tím moc párat nebude (1 běh a konec).
    sort_by_number_after_last_slash() {
      local -n -r input_reference="$1"
      local -n output_reference="$2"
      local -a -i input output
      local -a input_map
      local item
    
      for item in "${input_reference[@]}"; do
        input_map["${item##*/}"]="${item}"
      done
      input=("${!input_map[@]}")
      mergesort input output  # na hovno
      echo "${input[@]}"
      echo "${output[@]}"
      output_reference=()
      for item in "${output[@]}"; do
        output_reference+=("${input_map[item]}")
      done
    }
    
    Byť je tohle všechno na prd, jako zajímavá ukázka na hraní s Bashem to může být dobré (ten mergesort přinejmenším).
    declare -a -i unsorted=(RANDOM RANDOM RANDOM RANDOM RANDOM)
    declare -a -i sorted
    mergesort unsorted sorted
    echo "${unsorted[@]}"
    echo "${sorted[@]}"
    

    V tomto formuláři můžete formulovat svou stížnost ohledně příspěvku. Nejprve vyberte typ akce, kterou navrhujete provést s diskusí či příspěvkem. Potom do textového pole napište důvody, proč by měli admini provést vaši žádost, problém nemusí být patrný na první pohled. Odkaz na příspěvek bude přidán automaticky.

    Vaše jméno
    Váš email
    Typ požadavku
    Slovní popis
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.