Optimális esetben time és space complexity? C++
Ennél a feladatnál mi optimális megoldásnál a time és space complexity?
Kapok egy max 200 000 elemű 32 bites integer tömböt és minden elemet össze kell szorozni az (index szerint) utána következő elemekkel és a szorzatok összegét visszaadni modulo 1000000007.
Pl ha 2 4 7 van a tömbben akkor ezt az értéket kell visszaadni:
(2*4 + 2*7 + 4*7) % 1000000007 = 50
A 2 után a 4 és a 7 áll tehát azokkal kell összeszorozni, a 4 után pedig csak a 7 (és a 7 után pedig semmi).
Ha végig megyek minden párokon az ugye N^2 lenne de itt nem minden páron megyek végig mert az elemeket csak az utánuk következővel rakom párba. Ez ettől még N^2? Vagy van ennél jobb megoldás? A space complexity pedig O(1)?
Nem megoldásra vagyok kíváncsi (arra megpróbálok rájönni magamtól) csak a time és space complexityre.
Nyilván, de mivel csak a kompliexitás volt a kérdés, így ez irreleváns:)
Eyébként ahogy végigmész a tömön, úgy is össze lehet az eddigieket, nem kell egy külön lépésben előtte. Igazából csak arra reagáltam, hogy a kérdező azt írta, hogy: "A példában pl. a 2-t 11-el, a 4-et pedig 7-el."
Nyilván lehet úgy is, hogy a 4-t 2-vel szorzod, a 7-et pedig 6-tal... hiszen 2*11 + 4*7 = 2*4 + 6*7
Az utóbbihoz nem kell előre kiszámolni az összeget.
Mármint változó? Hát alapból kell amiben az eredményt számolod és egy ciklus változó. Ez már kettő... de a szorzás eredményé-t is külön el kell tárolni, hiába írod így:
eredmeny += x*y;
itt az x*y-t először kiszámolja a gép és valahol tárolja, még ha nincs is neve a programodban ennek külön.
Amúgy ez az, kezdjük lepontozni egymást... (Nem én kezdtem, senkit nem értékeltem itt korábban)
Ezt a kérdező írta... ezért kezdtem úgy a válaszom, hogy "Mármint változó?"
A kérdezőnek volt problémája azzal, hogy nem tud összeadni 2 számot, mert túlcsordul. Persze modulót számolhat már az elején, csak picit lassabb lesz a kód ha minden lépsben modulóz ahelyett, hogy a végén tenné ezt. De ezek részeltkérdések.
További kérdések:
Minden jog fenntartva © 2025, www.gyakorikerdesek.hu
GYIK | Szabályzat | Jogi nyilatkozat | Adatvédelem | Cookie beállítások | WebMinute Kft. | Facebook | Kapcsolat: info(kukac)gyakorikerdesek.hu
Ha kifogással szeretne élni valamely tartalommal kapcsolatban, kérjük jelezze e-mailes elérhetőségünkön!