program v pascale
program v pascale
mohli by ste mi pomoct vyriest tento problem?
Všeobecné zadanie
Vinár má k dispozícii sud vína. Obsah tohto suda chce bezozbytku rozliať do ďalších súdkov tak, aby súdok bol buď naplnený doplna, alebo aby nebol použitý vôbec. Vinár môže mať k dispozícii viac súdkov toho istého objemu.
Úloha 1: Vypočítajte programom a zobrazte na obrazovke všetky možné riešenia (kombinácie), ako je možné pôvodný objem sudu bezozbytku rozliať do ďalších súdkov.
Úloha 2: Vypočítajte programom a zobrazte na obrazovke optimálne riešenie (alebo riešenia), v ktorom (ktorých) je použitých najmenší počet súdkov.
Poznámka: Riešenie musí zobraziť výstup na obrazovke spôsobom, ako je ukázané nižšie. Nemeňte svojvoľne výstup programu, sťažujete tým kontrolu správnych výsledkov.
Konkrétne zadanie
Počet litrov vína k dispozícií: 24
Počet rôznych druhov sudov: 3
Jednotlivé sudy k dispozícii: 7x 4-litrový sud , 4x 8-litrový sud , 2x 12-litrový sud
Vzorové riešenie
Program SUDY
Celkovy objem vina: 24 litrov
1. typ sudku - objem: 4 L, pocet sudkov: 7
2. typ sudku - objem: 8 L, pocet sudkov: 4
3. typ sudku - objem: 12 L, pocet sudkov: 2
Riesenie c. 1: (0, 0, 2)
Riesenie c. 2: (0, 3, 0)
Riesenie c. 3: (1, 1, 1)
Riesenie c. 4: (2, 2, 0)
Riesenie c. 5: (3, 0, 1)
Riesenie c. 6: (4, 1, 0)
Riesenie c. 7: (6, 0, 0)
Celkovy pocet rieseni: 7
Optimalny pocet sudkov: 2
Optimalne riesenia: 1.
Poznámka: Riešenie (0, 0, 2) znamená použitie 0 súdkov s veľkosťou 4 litrov, 0 súdkov s veľkosťou 8 litrov a 2 súdkov s veľkosťou 12 litrov.
Všeobecné zadanie
Vinár má k dispozícii sud vína. Obsah tohto suda chce bezozbytku rozliať do ďalších súdkov tak, aby súdok bol buď naplnený doplna, alebo aby nebol použitý vôbec. Vinár môže mať k dispozícii viac súdkov toho istého objemu.
Úloha 1: Vypočítajte programom a zobrazte na obrazovke všetky možné riešenia (kombinácie), ako je možné pôvodný objem sudu bezozbytku rozliať do ďalších súdkov.
Úloha 2: Vypočítajte programom a zobrazte na obrazovke optimálne riešenie (alebo riešenia), v ktorom (ktorých) je použitých najmenší počet súdkov.
Poznámka: Riešenie musí zobraziť výstup na obrazovke spôsobom, ako je ukázané nižšie. Nemeňte svojvoľne výstup programu, sťažujete tým kontrolu správnych výsledkov.
Konkrétne zadanie
Počet litrov vína k dispozícií: 24
Počet rôznych druhov sudov: 3
Jednotlivé sudy k dispozícii: 7x 4-litrový sud , 4x 8-litrový sud , 2x 12-litrový sud
Vzorové riešenie
Program SUDY
Celkovy objem vina: 24 litrov
1. typ sudku - objem: 4 L, pocet sudkov: 7
2. typ sudku - objem: 8 L, pocet sudkov: 4
3. typ sudku - objem: 12 L, pocet sudkov: 2
Riesenie c. 1: (0, 0, 2)
Riesenie c. 2: (0, 3, 0)
Riesenie c. 3: (1, 1, 1)
Riesenie c. 4: (2, 2, 0)
Riesenie c. 5: (3, 0, 1)
Riesenie c. 6: (4, 1, 0)
Riesenie c. 7: (6, 0, 0)
Celkovy pocet rieseni: 7
Optimalny pocet sudkov: 2
Optimalne riesenia: 1.
Poznámka: Riešenie (0, 0, 2) znamená použitie 0 súdkov s veľkosťou 4 litrov, 0 súdkov s veľkosťou 8 litrov a 2 súdkov s veľkosťou 12 litrov.
cykly cykly vsetkych moznosti. jak obvykle....no co uz sa to asi nezmeni
Kód: Vybrať všetko
uses crt;
var a,b,c:byte;
opt,kolke,ries,cele:word;
begin
opt:=7*4*2;
ries:=0;
cele:=24;
clrscr;
for a:=0 to 7 do
for b:=0 to 4 do
for c:=0 to 2 do
if(a*4+b*8+c*12=cele) then begin
inc(ries);
if(opt>a+b+c) then begin
opt:=a+b+c;kolke:=ries;
end;
writeln('Riesenie c. ',ries,': (',a,',',b,',',c,')');
end;
writeln('---------vysledky---------');
writeln('Celkovy pocet rieseni: ',ries);
writeln('Optimalny pocet sudkov: ',opt);
writeln('Optimalne riesenie: ',kolke,'.');
end.ale co by nebolo je to spravne len tu mame debatu ze keby bolo upne ine zadanie, cize ine vahy a ina cielova hmotnost, tak by sa mohlo stat ze bude viac "optimalnych rieseni" co pri tomto nebude ale keby tak by sa to muselo osetrit. a teda o poliach tam v tvojom nic nepisu ani o dalsich a ten priklad je urceny na jedno takze nevidim problem.D4K4P0 napísal:takze to co si napisal nie je spravne?
inac dik ze si sa aspon snazil vazim si to
a o vine uz ani debaty