Pereiti prie turinio

[C++] Masyvo uždavinys


Rekomenduojami pranešimai

Sveiki, reikia išspręsti vieną uždavinį su c++ masyvais.

Atrodo su kodu viskas tvarkoje, bet paleidus programą meta begalines reikšmes, o ciklas nesustoja... Klaida, kaip suprantu, su antru ciklu. Esme tame,kad man reikia, kad ciklas sumuotų visus elementus,kol jų suma pasieks masyvo,pirmo elemento kvadratinę reikšmę.

Būčiau labai dėkingas už pagalbą.

Uždavinio sąlyga:

Duotas masyvas X(n). Masyvo dydį įveskite vykdant programą, o masyvo elementus generuokite atsitiktinai. Sumuokite elementus tol, kol suma neviršija pirmo elemento kvadrato (arba iki galo). Išveskite masyvo elementus ir gautą sumą.

#include <iostream>

#include <stdlib.h>

#include <cmath>

using namespace std;

 

int main()

{

int n,i,sum;

int X[] = {};

cout << "Iveskite masyvo dydi: ";

cin >> n;

 

for(i = 0;i <= n;i++){

X[n] = (rand() % 100 + 1);

cout << X[n] << endl;

}

n = 1;

sum = 0;

while(sum <= pow(X[1],2)){

sum += X[n];

n++;

}

 

cout <<"Suma: ";

cout << sum <<endl;

 

 

 

 

return 0;

}

Redagavo arvydas999
Nuoroda į pranešimą
Dalintis kituose puslapiuose
#include <iostream>
#include <stdlib.h>
#include <cmath>
using namespace std;

int main()
{

int n;
cout << "Iveskite masyvo dydi: ";
cin >> n;

//Nenurodai masyvo dydžio, klaida.
int X[n]={ };

   for(int i = 0; i < n; i++)
   {
       //Cia isvis, pradedi masyva nuo elementu skaiciaus, o ne nuo 0... - pas tave X[n] ir visados X[n], nenurodai, kad kreipiesi i sekanti masyvo elementa
       X[i] = (rand() % 100 + 1);
       cout << X[i] << endl;
   }

//Jeigu skaiciuojam bendra suma + pirmas elementas tada pakeisk i i=0
int sum=0, i=1, 

//Pirmo elemento kvadratas..
int power = pow(X[0],2);

   while(sum <= power && i<n)
   {
       //Patikrinam dabar esama suma + paimam sekanti elementa ir prideda ji i suma
       int arVirsijaSuma = sum + X[i];

       //Patikrinam ar tuomet suma virsytu pirmo elemento kvadrata
       if ( (arVirsijaSuma) > power )
       {
           //Jeigu virsijo - nutraukiam cikla
           break;
       }
       //Jeigu nevirsijo
       else
       {
        //Pridedam ta elementa i suma, padidinam i vienetu ir paimam sekanti elementa - sukam cikla isnaujo
         sum+=X[i];
         i++;
       }

   }

   //Paskutine elementu suma, kuri nevirsija pirmo elemento kvadrato
   cout <<"Suma: " << sum <<endl;



return 0;
}

Redagavo ReborN
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Masyvo pirmasis elementas - X[0], o ne X[1], bandyk pasitaisyt, gal šitame bėda

 

Tai, kad... :) pas jį masyvo dydis nenurodytas + masyvą pradeda nuo elementų skaičiaus t.y

 

Jeigu nurodė, kad bus 5 elementai tai pagal jo kodą masyvą jis pradeda X[5] ir niekad nekeičia pozicijos tai visi elementai ir rašosi ant X[5] :)

Nuoroda į pranešimą
Dalintis kituose puslapiuose

i = 0;
sum = 0;
while(sum <= pow(X[0],2))
{
if (i > n) break;
sum += X[i];
i++;
}

 

realiai pas tave klaida, nes masyvo indeksaciją ne nuo 0, bet nuo 1 imi.

 

Na daug indeksacija nepadės, kai masyvo elementai surašyti ne nuo 0, o nuo 'n'. :) + kaip supratau pagal aprašą tai jam net nereikia 1 elemento sudėti, kadangi jis tik palyginimui taip, kad jis kaip ir yra teisus. :)

Redagavo ReborN
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Na daug indeksacija nepadės, kai masyvo elementai surašyti ne nuo 0, o nuo 'n'. :) + kaip supratau pagal aprašą tai jam net nereikia 1 elemento sudėti, kadangi jis tik palyginimui taip, kad jis kaip ir yra teisus. :)

 

for(i = 0;i <= n;i++){

X[n] = (rand() % 100 + 1);

 

Deda į masyvą nuo 0-ojo elemento (Žmogiškai - pirmasis)

 

while(sum <= pow(X[1],2))

 

Lygina su pirmuoju masyvo elementu (Žmogiškai - antruoju):)

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ą...