Ubuntu Cinnamon bude od Ubuntu 23.04 oficiální odnoží Ubuntu (návrh, schválení).
Byla vydána nová major verze 5.0 účetního softwaru GnuCash (Wikipedie). Ve formátu Flatpak je již k dispozici na Flathubu.
Na GOG.com běží Spring Sale. Při té příležitosti lze získat zdarma počítačovou hru Alwa's Awakening (ProtonDB).
Byla vydána verze 3.28.0 2D CAD (computer-aided design) softwaru QCAD (Wikipedie). Přehled novinek v Changelogu.
Změna ve vedení společnosti SUSE. Dosavadní CEO Melissa Di Donato odstoupila. Od 1. května je novým CEO Dirk-Peter van Leeuwen, bývalý Senior Vice President a General Manager ve společnosti Red Hat.
CyberChef je webová aplikace pro analýzu dat a jejich kódování a dekódování, šifrování a dešifrování, kompresi a dekompresi, atd. Často je využívaná při kybernetických cvičeních a CTF (Capture the Flag). Vydána byla nová major verze 10 (aktuálně 10.4.0). Přehled novinek v Changelogu.
UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch OTA-1 Focal založené na Ubuntu 20.04 Focal Fossa.
Společnost Red Hat slaví 30 let.
Ve věku 91 let zemřel izraelský informatik Ja'akov Ziv, spolutvůrce bezztrátových kompresních algoritmů LZ77, LZ78 a LZW (Lempel–Ziv–Welch).
Byla představena nová Arduino deska Arduino UNO R4 s 32bitovým MCU RA4M1 (Arm Cortex-M4). Desku lze zatím získat pouze v rámci early access programu.
Dobry den, rad bych si vytvoril tridu zdedenou od tridy ArrayList, chci pridat pouze jednu metodu a to boolean metodu, ktera bude zjistovat, zda pro vsechny prvky seznamu plati
a[i]=i;
Zacal jsem takto:
public class ArrayListCustom Integer extends ArrayList Integer { public ArrayListCustom() { super(); } public boolean isLinear() { } }
Ale v tele metody isLinear jsem se zasekl, protoze vlastne nevim, jak mohu pristupovat k prvkum toho seznamu. Muzete prosim poradit?
neda se pro arraylist pouzit indexy a pak pristupovat ke kazdemu indexu zvlast?
Resit se to da velmi jednoduse - deite od ArrayList
, tudiz mate u objektu this
pristup ke vsem public
a protected
metodam materske tridy. Implementace tridy s metodou isLinear
muze vypadat treba takto:
public class ArrayListCustom extends ArrayList<Integer> { public static final long serialVersionUID = 1l; public ArrayListCustom() { super(); } public boolean isLinear() { boolean result = true; for (int i = 0; i < this.size(); i++) { if (this.get(i) != i) { result = false; break; } } return result; } }
btw. pokud neplanujete psat tu tridu genericky, ale jen pro jeden typ (Integer
), je lepsi v nazvu tridy kompletne vynechat definici generickeho typu. Viz kod v prikladu.
S pozdravem, Marek Siller
To je presne ono, dekuji:)
Trochu rychlejší řešení by mohla být iterace z obou stran. Pokud array list nabývá vetších rozměrů, tak je to i znatelné.
Nejrychlejší řešení je však vytvořit vlastní handle na metody add, get. Poté by zjištění vaší linearity bylo konstantní.
public class ArrayListCustom extends ArrayList<Integer> { public static final long serialVersionUID = 1L; public ArrayListCustom() { super(); } public boolean isLinear() { for (int i = 0, size = this.size(), j = size - 1; i < size && j >= i; i++; j--) { if (this.get(i) != i || this.get(j) != j) { return false; } } return true; } }
Tiskni
Sdílej: