Kezdőoldal » Számítástechnika » Programozás » Milyen algoritmussal lehetne...

Milyen algoritmussal lehetne a leghatékonyabban megoldani a következő problémát?

Figyelt kérdés
Ha van nekem 500 darab számhármasom (pl: { {1: x=20, y=50, z=30 }, {2: x=80, y=40, z=20} ... {500: x= 44, y= 11, z= 99}} és én megadok egy számhármast (pl: {x= 210, y= 300, z=180}) akkor megtalálni azt a kombinációját (ismétléssel és anélkül is) az 500 számhármasomnak, amelyben a számok x y és z helyen álló számok összege a kívánt értékhez a legközelebbi? Tehát a fenti példában olyan számhármasokat keresk ahol az x-ek összege 210 az y-ok összege 300, a Z-k összege 180. Ha ilyen nincs akkor a legközelebbit megtalálni.

2023. jan. 19. 20:34
1 2 3
 1/25 anonim ***** válasza:
36%
Ennek fuss neki újra, mert így érthetetlen.
2023. jan. 19. 20:57
Hasznos számodra ez a válasz?
 2/25 A kérdező kommentje:

Rendben. Tehát vannak számhármasaim, tegyük fel az egyszerűség kedvéért, hogy 500 helyett csak 3 darab. { {x=20, y=50, z=30 }, {x=80, y=40, z=20}, {x= 44, y= 11, z= 99}}. Fel is lehet úgy fogni mint egy objektum gyűjteményt, ahol az objektumoknak három property-je van (x, y, z).


Aztán. Én megadom paraméterben azt, hogy {x = 100, y = 61, z = 129}, és erre szeretném visszakapni azokat a számhármasokat (objektumokat) amelyeknek a különböző elemeinek az összege kiadja ezeket az értékeket. Vagyis az X összegek, az Y összegek, és a Z összegek. Ebben a példában az 1. és a 3. a válasz vagyis: { {x=20, y=50, z=30 }, {x= 44, y= 11, z= 99}} mivel x1 + x3 = 100, y1 + y3 = 61, z1 + z3 = 129.


Ha pedig nincs pontosan ilyen érték, akkor a legközelebbit. Ha még mindig kicsit kusza, kérlek szólj megint. És köszönöm a gyors választ.

2023. jan. 19. 21:19
 3/25 anonim ***** válasza:

Arra vagy kíváncsi, hogy milyen egy konkrét algoritmussal lehetne ezt megoldani (fogalmam sincs, hogy van-e erre) vagy inkább az érdekelne, hogy aki programozó az milyen algoritmust írna erre a problémára?


Ha az első eset áll fenn, akkor lehet van aki tud segíteni, de én még algoritmusok óráról se emlékszem ilyesmire ami jó erre, aztán persze lehet volt:D

Viszont ha a második eset áll fenn, akkor már lehet tudnék én is és mások is segíteni.


A második esethez annyit kérdeznék előre, hogy maximum 500 darab ilyen számhármas lehet vagy ezt csak úgy példának mondtad?

A legközelebbi esetét nézve pedig mi legyen, ha egynél több is ugyan annyira lenne közel?

2023. jan. 19. 21:33
Hasznos számodra ez a válasz?
 4/25 anonim ***** válasza:
20%
Sima egyszerű min keresés.
2023. jan. 19. 21:55
Hasznos számodra ez a válasz?
 5/25 A kérdező kommentje:

Köszönöm a hozzászólást. Igen, a második (programozó megközelítés) tökéletesen megfelelő lenne. Szóval igen, maximum 500-ban maximalizáljuk. Viszont fontos, hogy kell példa arra az esetre is amikor ismétlődhetnek az elemek, és olyanra is amikor nem.


Ami a legközelebbi esetet illeti, valójában az lenne a legjobb, ha a legközelebbi 5-öt adná vissza mindig (ha van pontos találat ha nincs). Ha több mint 5 ugyanolyan közel van, akkor mindegy melyik 5 a kiválasztott. De ha az 5 legközelebbit visszaadni macera, akkor elég az egyetlen legközelebbi is (ebben az esetben egyenlő esetén mindegy melyik)

2023. jan. 19. 22:00
 6/25 A kérdező kommentje:

Tehát a visszatérési érték az egy 5 elemű, tömböket tartalmazó tömb. pl:

[

[{x=20, y=50, z=30 }, {x= 44, y= 11, z= 99}],

[{x=50, y=20, z=70 }, {x=220, y=530, z=130 }, {x= 4, y= 1, z= 9}]

]

2023. jan. 19. 22:03
 7/25 A kérdező kommentje:
amit írtam az 2 elemű, de értelemszerűen, akár lehetne 5 is.
2023. jan. 19. 22:04
 8/25 anonim ***** válasza:
100%

Ha felfogod az xyz-ket egy 3 dimmenziós tér pontjainak.


Megoldás #1: parasztba összeadsz minden pontot mindennel így új pontokat létrehozva, amikben tárolod, hogy melyekből jött ki.


Minden pontot kategorizálsz hogy a 3 tengelyű koordinátán hol helyezkedik el. Ebből ugye 8 van:

- x,y,z

- -x,y,z

- x,-y,z

- -x,-y,z

Ugyanezek -z vel. Mínuszok akkor, ha megengedett a negatív. Ha nem, csak egy zónád lesz a x,y,z.


Továbbá minden ponthoz rendelsz távolságoz a zérus helytől.


Sokat fog foglalni, de cserébe gyors lesz. És ha beadsz egy koordinátát, akkor nemes egyszerüséggel számolsz egy závolságot, negatív számok esetén tudod mely koordináta zónában vagy. Innentől a legközelebbi pontot kell megtalálni, így meg is van azok a x,y,z számhármas amikből kijönne.

2023. jan. 19. 22:04
Hasznos számodra ez a válasz?
 9/25 anonim ***** válasza:

#8 wow, zseniális válasz!


Én arra amúgy kíváncsi lennék, hogy milyen nyelvet használsz kérdező? Mert ha pythont, akkor lehet kevésbé matekos megoldást is kihozni pandas és numpy segítségével. De ez mondjuk nem változtat a tényen, hogy #8 válasza lesz a leggyorsabb és legszebb megoldás, wow.

2023. jan. 19. 22:19
Hasznos számodra ez a válasz?
 10/25 anonim ***** válasza:

"Ebben a példában az 1. és a 3. a válasz vagyis: { {x=20, y=50, z=30 }, {x= 44, y= 11, z= 99}} mivel x1 + x3 = 100, y1 + y3 = 61, z1 + z3 = 129"

20 + 44 < 100 ?? Miért x1 + x3 = 100 ?

50 + 11 = 61

99 + 30 = 129


"Sokat fog foglalni, de cserébe gyors lesz."

A legenerálás viszont nem lesz gyors. Ordóba köbös idejű és tárigényű/memória igényű.


"én még algoritmusok óráról se emlékszem ilyesmire ami jó erre, aztán persze lehet volt"

Pedig volt. Ládapakolási algoritmus angolul bin packing, röviden BP.

Algoritmusok közül a kombinatorikus optimalizálási feladathoz tartozik.

2023. jan. 19. 22:22
Hasznos számodra ez a válasz?
1 2 3

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

A weboldalon megjelenő anyagok nem minősülnek szerkesztői tartalomnak, előzetes ellenőrzésen nem esnek át, az üzemeltető véleményét nem tükrözik.
Ha kifogással szeretne élni valamely tartalommal kapcsolatban, kérjük jelezze e-mailes elérhetőségünkön!