Pereiti prie turinio

C++ užduotis. Need help


Rekomenduojami pranešimai

Sveiki,

Reikėtu šiek tiek pagalbos.

Išspręsti uždaviniui visų pirmą reikėtų susiskirstyti visas kainas į atskiras lentynas t.y kiekvieną kainą suvesti į tam tikrą masyvą(lentyną), bet kaip tai padaryti neįsivaizduoju. Juk kiekvienoj lentynoj skirtingas kiekis prekių. Gal kas pagelbėsit ar bent ant kelio užvesit ?

post-60150-0-17489100-1451767171_thumb.png

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Sveikas, aš atlikčiau šią užduotį taip:

Nuskaityčiau p ir n, tada for ciką n kartų. Tame cikle sukurti kintamajį max = 0(Suras brangiausią prekę), tada vėl for ciklą(pirmo viduje) ir ten skenuoti duotus duomenis ir jei jo kaina didesnė už max, tai paversti jį nauju max. Kai baigsis tas ciklas pažiūrėti ar if(p-max >= 0) ir atimti iš p max. Taip pat sukurti kintamąjį, kuris skaičiuos kiek kartų if(p-max >= 0 ) pavyko :)

 

Taip pat reiktų tikrinti ar max nėra didesnis už p kai tikrini naują sumą(čia antram pvz)

Redagavo xxjonasxxs
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Sveikas, aš atlikčiau šią užduotį taip:

Nuskaityčiau p ir n, tada for ciką n kartų. Tame cikle sukurti kintamajį max = 0(Suras brangiausią prekę), tada vėl for ciklą(pirmo viduje) ir ten skenuoti duotus duomenis ir jei jo kaina didesnė už max, tai paversti jį nauju max. Kai baigsis tas ciklas pažiūrėti ar if(p-max >= 0) ir atimti iš p max. Taip pat sukurti kintamąjį, kuris skaičiuos kiek kartų if(p-max >= 0 ) pavyko :)

 

Taip pat reiktų tikrinti ar max nėra didesnis už p kai tikrini naują sumą(čia antram pvz)

Bet supranti jei n kartu skaityt, tai nuskaitys pirmus 4 skaitmenis. Jei ieškosiu max, man ras 900 poto 800 ir t.t. Man reikia kiekvienoj lentynoj rasti didžiausią ir paskui jį atimti. Jei pinigų neužtenka, tiesiog praeiti.

Nuoroda į pranešimą
Dalintis kituose puslapiuose

#include <fstream>
#include <iostream>

using namespace std;

main()
{

int p,n, gali_nusipirkti=0;

freopen("lentynos.in", "r",stdin	);

scanf("%d%d", &p,&n);

for(int x = 0; x < n; x++)
{

	int prekiu_kiekis;

	scanf("%d", &prekiu_kiekis);

	int max_kaina = 0;

	for(int x = 0; x < prekiu_kiekis; x++)
	{

		int kaina;

		scanf("%d", &kaina);

		if(max_kaina < kaina && p-kaina >= 0)
		{

			max_kaina = kaina;


		}

	}

	if(p-max_kaina >= 0 && max_kaina != 0)
	{

		p-=max_kaina;

		gali_nusipirkti++;

	}

}

cout << "Gali nusipirkti " << gali_nusipirkti << endl;

cout << "Pinigu liks " << p << endl;

system("pause");

return 0;
}

lentynos.in >

1000 4
3 15 360 8
5 2 1 145 99 300
4 700 600 900 800
2 8 1

Redagavo donce16
Nuoroda į pranešimą
Dalintis kituose puslapiuose

#include <fstream>
#include <iostream>

using namespace std;

main()
{

int p,n, gali_nusipirkti=0;

freopen("lentynos.in", "r",stdin	);

scanf("%d%d", &p,&n);

for(int x = 0; x < n; x++)
{

	int prekiu_kiekis;

	scanf("%d", &prekiu_kiekis);

	int max_kaina = 0;

	for(int x = 0; x < prekiu_kiekis; x++)
	{

		int kaina;

		scanf("%d", &kaina);

		if(max_kaina < kaina && p-kaina >= 0)
		{

			max_kaina = kaina;


		}

	}

	if(p-max_kaina >= 0 && max_kaina != 0)
	{

		p-=max_kaina;

		gali_nusipirkti++;

	}

}

cout << "Gali nusipirkti " << gali_nusipirkti << endl;

cout << "Pinigu liks " << p << endl;

system("pause");

return 0;
}

lentynos.in >

1000 4
3 15 360 8
5 2 1 145 99 300
4 700 600 900 800
2 8 1

Dėkoju :)

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...