abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×

    včera 23:22 | Nová verze

    Byla vydána Beta 1 verze KDE 6 (Plasma, Frameworks a Gear) postavené na Qt 6. Testovat lze například v distribuci KDE Neon. Stabilní verze je plánována na konec února 2024. Předchozí velké vydání 5 vylo vydáno téměř před 10 lety (červenec 2014).

    Ladislav Hagara | Komentářů: 1
    včera 23:00 | Komunita

    Open-source webmail Roundcube se připojil k balíku aplikací Nextcloudu. Převzetí firmou Nextcloud ale plánováno není, pouze integrace a podpoření vývoje.

    Fluttershy, yay! | Komentářů: 0
    včera 18:44 | IT novinky

    Stability AI představila SDXL Turbo, tj. umělou inteligenci pro generování obrázků z textového popisu v reálném čase, viz ukázka na YouTube.

    Ladislav Hagara | Komentářů: 0
    včera 12:33 | Nová verze

    Svobodná webová platforma pro sdílení a přehrávání videí PeerTube (Wikipedie) byla vydána v nové major verzi 6. Přehled novinek i s náhledy a videi v oficiálním oznámení a na GitHubu (6.0.0, 6.0.1).

    Ladislav Hagara | Komentářů: 0
    včera 11:55 | IT novinky

    S eDoklady lze mít od ledna 2024 občanku v mobilní aplikaci [Digitální a informační agentura – DIA].

    Ladislav Hagara | Komentářů: 3
    včera 07:00 | IT novinky

    Google představil novou doménu nejvyššího řádu: .meme. Viz například knowyour.meme nebo find.meme.

    Ladislav Hagara | Komentářů: 9
    28.11. 21:22 | IT novinky

    IKEA představila 3 senzory pro chytrou domácnost: senzor na dveře a okna PARASOLL, bezdrátový pohybový senzor VALLHORN a senzor úniku vody BADRING. Budou kompatibilní s Home Assistant?

    Ladislav Hagara | Komentářů: 1
    28.11. 20:44 | Nová verze

    Weston, referenční implementace kompozitoru pro Wayland, byl vydán ve verzi 13.0.0. Přehled novinek v oznámení.

    Ladislav Hagara | Komentářů: 0
    28.11. 17:55 | Nová verze

    Laboratoře CZ.NIC vydaly novou verzi 4.23.0 aplikace Datovka, tj. svobodné multiplatformní desktopové aplikace pro přístup k datovým schránkám a k trvalému uchovávání datových zpráv v lokální databázi. Přidána byla podpora pro velkoobjemové datové zprávy (VoDZ) a pro typy datových schránek PFO_ARCH, PFO_AIAT a PFO_AZI. Další novinkou je pamatování velikosti dialogových oken, pozice ovládacích prvků, šířek sloupců a řazení položek

    … více »
    Ladislav Hagara | Komentářů: 0
    28.11. 17:33 | Nová verze

    Distribuce Tails specializující se ochranu online soukromí uživatele byla vydána ve verzi 5.20. Mimo jiné aktualizuje Tor Browser (13.0.4) a Thunderbird (115.5), opravuje několik chyb.

    Fluttershy, yay! | Komentářů: 0
    Používáte modální textový editor?
     (75%)
     (3%)
     (2%)
     (20%)
    Celkem 285 hlasů
     Komentářů: 8, poslední 16.11. 22:24
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: posun prvku matice

    26.11.2009 13:39 Pavel
    posun prvku matice
    Přečteno: 453×
    Zdravim, potreboval bych poradit, jak posunout prvky matice o jeden dopredu......?

    Ukazka:

    1 2 3 4 5 6

    =>

    6 1 2 3 4 5

    Praci s polema uz celkem zvladam, ale na tohle nejak nemuzu prijit:-(....

    predem diky za rady

    Odpovědi

    26.11.2009 14:08 Zdenek
    Rozbalit Rozbalit vše Re: posun prvku matice
    Uz zase domaci ukol? A co s tema polema zvladas? Umis uz zasit obili?
    26.11.2009 14:30 Pavel
    Rozbalit Rozbalit vše Re: posun prvku matice
    no, co se tyce poli tak sem si zkousel bublinkove trideni, prohazovani radku, sloupcu, hledani maxima,..........

    necekam ze mi to nekdo napise za me.....jen poradi, jak na to......
    26.11.2009 14:37 rastos | skóre: 62 | blog: rastos
    Rozbalit Rozbalit vše Re: posun prvku matice
    1 2 3 4 5 6
    
    1 2 3 4 5 6     6
    1 2 3 4 5→5
    1 2 3 4→4 5
    1 2 3→3 4 5
    1 2→2 3 4 5
    1→1 2 3 4 5
    
    6 1 2 3 4 5
    26.11.2009 14:46 Zdenek
    Rozbalit Rozbalit vše Re: posun prvku matice
    Hezke. Ja radil tohle :-)
    1 2 3 4 5 6
    
    1 2 3 4 5←6
    1 2 3 4←6 5
    1 2 3←6 4 5
    1 2←6 3 4 5
    1←6 2 3 4 5
    
    6 1 2 3 4 5
    
    26.11.2009 14:39 Zdenek
    Rozbalit Rozbalit vše Re: posun prvku matice
    Kdyz uz umis tridit tak posun je prece hracka. Nebo to "zkousel jsem" znamena, ze to za tebe nekdo napsal a tys to spustil? No, ale abys nerekl, ze neporadim tak pro zacatek bys mohl treba prohodit par sloupcu, to uz prece umis, co ty na to?
    26.11.2009 15:02 Pavel
    Rozbalit Rozbalit vše Re: posun prvku matice
    no tohle je neco jineho nez trideni - tohle je Dvourozmerna matice , kde na vstupu zadavam jeji rozmery.....muzu sem dat ukazku kodu, ale nefunguje:-(.....
    26.11.2009 17:37 Zdenek
    Rozbalit Rozbalit vše Re: posun prvku matice
    Jen ho sem dej, neco s nim udelame a hlavne se dozvime v jakem ze to ma byt jazyku :-)
    26.11.2009 19:14 Pavel
    Rozbalit Rozbalit vše Re: posun prvku matice
    tak se davam ten kod, nemam tam komentare, tak trochu vysvetlim jak by to melo fungovat....

    http://pastebin.com/m72f07962 http://pastebin.com/m33bca2b5

    mam dve tridy - trida Matice a Main

    Matice obsahuje: konstruktor pro vytvoreni dvou matic(rozmery zadane uzivatelem) a druhou - pomocnou, do ktere budu ukladat "orotovanou" matici.....dale obsahuje metody pro naplneni matice, vypis, a orotovani(coz se mi bohuzel nedari:-()

    ve tride Main si nejprve vytvorim objekt(pomocnou matici a tu, kterou uzivatel zada), dale ji naplnim, vypisu, pak volam metodu "orotuj" a pak vypisuju orotovanou......nevim vcem je problem, ostatni ukoly jsem zvladl, ale tenhle se mi nedari...

    predem moc dekuju za pomoc...

    26.11.2009 20:49 Zdenek
    Rozbalit Rozbalit vše Re: posun prvku matice
    Proc u obou for cyklu odecitas jednicku v testovaci podmince?
    
            public void orotujMatici() {
                int predchozi = 1;
                for (int i = 0; i < zadanaMatice.length - 1; i++) {
                for (int j = 0; j < zadanaMatice[0].length - 1; j++) {
                   if((i == 0) && (j == 0)) predchozi = zadanaMatice[pocetRadku - 1][pocetSloupcu - 1];
                   if((j == 0) && (i != 0)) predchozi = zadanaMatice[i-1][pocetSloupcu - 1];
                   if(j != 0) predchozi = zadanaMatice[i][j - 1];
    
                   orotovanaMatice[i][j] = predchozi;
                }
              }
            }
    
    26.11.2009 21:32 Pavel
    Rozbalit Rozbalit vše Re: posun prvku matice
    no myslel sem ze zadanaMatice.lenght mi vraci int pocet (treba ze ma 2 sloupce), ale jelikoz pole se mi indexuje od 0, tak (abych "nepretekl") to odecitam....

    pole ktere ma 2 sloupce, ma prece maximalni index 1......

    vidim, ze bez toho to funguje, ale nejak sem si vtiom uhdelal gulas......:-(
    26.11.2009 21:41 Zdenek
    Rozbalit Rozbalit vše Re: posun prvku matice
    To sis myslel dobre, ale pak si nemel pouzit podminku "mensi nez" :-)
    26.11.2009 22:07 Pavel
    Rozbalit Rozbalit vše Re: posun prvku matice
    nechapu....pak by tom bylo mensi nebo rovno??
    26.11.2009 23:00 vencas | skóre: 32
    Rozbalit Rozbalit vše Re: posun prvku matice
    Spočítej si na prstech, jakých hodnot bude i nabývat... (nápověda: Zdeněk má pravdu a pochopils to správně)
    27.11.2009 11:43 Pavel
    Rozbalit Rozbalit vše Re: posun prvku matice
    uz to chapu, musel sem si tu matici nakreslit na papir....

    este mam ale dotaz: je to hodne prasacky napsany?? jak byste to resili Vy profici?? (nechci celej kod, jen popsat, jak byste to podle toho zadani resili Vy???)

    Diky
    27.11.2009 19:14 ::: | skóre: 14 | blog: e_lama
    Rozbalit Rozbalit vše Re: posun prvku matice
    Ja bych to resil nejak takhle: (je to jenom pseudo-kod)
    class Matice:
    
            Matice (pocet_radku, pocet_sloupcu):
                    M = new int[pocet_radku * pocet_sloupcu];
                    offset = 0
    
            int prvek(int radek, int slupec):
                    return M[ (pocet_sloupcu * radek + sloupec + offset) % (pocet_radku * pocet_sloupcu) ];
    
            void orotuj():
                    offset += pocet_radku * pocet_sloupcu - 1;
                    offset %= pocet_radku * pocet_sloupcu;
    
    
    a obesel bych se uplne bez kopirovani pameti.

    Samozrejme v realny aplikaci by volba konkretniho algoritmu zalezela na spouste dalsich faktoru ( napr. jak casto budu provadet tuhle operaci a jak casto nejaky jiny ? je tahle reprezentace matice vhodna i pro ostatni operace s ni ? atd. ... )
    27.11.2009 08:24 rastos | skóre: 62 | blog: rastos
    Rozbalit Rozbalit vše Re: posun prvku matice
    Ak tomu dobre rozumiem tak metoda orotujMatici() pri j==0 a i==0 urobi

    orotovanaMatice[0][0]= zadanaMatice[pocetRadku - 1][pocetSloupcu - 1]

    Ale tak, ako som to pôvodne pochopil, by malo byť možné použiť systém, kedy máš metódu, ktorá zarotuje len jeden riadok a túto metódu postupne zavolať na všetky riadky. Inými slovami, nemá dochádzať k presunu medzi riadkami (a fungovanie takej metódy som navrhol vyššie). Ako je to? Daj príklad, na maticu, ktorá má viac ako jeden riadok.

    Zdenek: pri tvojom riešení vymieňaš prvky. To znamená 3 priradenia na jeden krok. Pri mojom riešení, je to len jedno.

    masomlejn avatar 26.11.2009 16:46 masomlejn | skóre: 16
    Rozbalit Rozbalit vše Re: posun prvku matice
    
    program shift_array
      implicit none
      integer, parameter :: max=6 
      integer            :: i, j
      integer            :: a(max)
    
      a = (/1, 2, 3, 4, 5, 6/)
      print'(a12,x,6(i2,1x))',"A(puvodni)= ",(a(i), i=1,max)
      a = cshift(a,-1)
      print'(a12,x,6(i2,1x))',"A(nova)= ",(a(i), i=1,max)
    end program shift_array
    
    
    A potom
    [milan@penguin-shift-array]$ gfortran -o shift-array shift-array.f90
    [milan@penguin-shift-array]$ ./shift-array
    A(puvodni)=   1  2  3  4  5  6
       A(nova)=   6  1  2  3  4  5
    [milan@penguin-shift-array]$
    
    29.11.2009 10:41 Kill_Bill
    Rozbalit Rozbalit vše Re: posun prvku matice
    Jen technicka poznamka, kdyz vidim "Class Matice..." - profi. resice soustav rovnic se dodnes pisi ve Fortranu. Objekty jsou proste fajn ale ta rezie...

    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.