Pereiti prie turinio

C++ užduotis su masyvo nuskaitymu iš failo


Rekomenduojami pranešimai

Reikia pagalbos,nes esu visiškai žalias programavime.

Turiu užduoti ir nežinau nuo ko pradėt.

Duotas dvimatis masyvas E(m,m). m ir masyvo elementų reikšmės saugomi tekstiniame faile.

Parašti programa kuri rastų pagrindinės matricos istrižainės didžiausia ir mažiausia reikšmę ir apkeistų jas vietomis.

Rezultatus išvesti į failą "rezultatai.txt".

Prašau jeigu kas nors suprantat gerai tai nepatingėkit padėt.

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Tai pagrindine istrizaine randama kai abu masyvo indeksai i ir j sutampa, siuo atveju m turi buti lygu m.

Tuomet suki cikla ir tikrini ar daugiau uz max arba maziau uz min. Issisaugoji min ir max reiksmiu masyvo indeksus ir kai baigsis ciklas, tiesiog apkeiti vietomis reiksmes.

Redagavo MindeB
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Meta viena errora kazkas negerai. O pats algoritmas bent panasiai turi atrodyt? kur klaida gali but?

 

 

 

#include <iostream>

#include <fstream>

#include <iomanip>

using namespace std;

#define vKiek 50

int A[vKiek][vKiek];

void Skaityti(int &n, int& m, int A[vKiek][vKiek]);

void Veiksmai(int A[vKiek][vKiek], int n, int m);

void Spausdinti(int A[vKiek][vKiek], int n, int m);

void main()

{

int n, m;

Skaityti(n, m, A);

Veiksmai(A, n, m);

Spausdinti(A, n, m);

 

}

 

void Skaityti(int &n, int& m, int A[vKiek][vKiek])

{

 

ifstream df("Duomenys.txt");

df >> n >> m;

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

{

for (int j = 0; j < m; j++)

{

df >> A[j];

}

}

 

df.close();

}

 

void Veiksmai(int A[vKiek][vKiek], int n, int m)

{

int r;

int min = A[0][0];

int max = A[0][0];

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

{

if (A>max)

{

i = max;

}

 

if (A < min)

{

i = min;

}

}

r = A[min][min];

A[min][min] = max;

A[max][max] = min;

 

 

 

 

 

void Spausdinti(int A[vKiek][vKiek], int n, int m);

{

 

ofstream rf("Rezultatai.txt");

rf << A;

}

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Turi klaidu:

void Veiksmai(int A[vKiek][vKiek], int n, int m)
{
   int r; // kam jis skirtas?
   int min = A[0][0]; // truksta elementu, pridek pvz minXY = 0 - kuris seka indexa i
   int max = A[0][0]; // kaip ir min, pridek pvz maxXY = 0 - kuris seka indexa i
   for (int i = 0; i <n; i++) { // gali pradeti nuo 1, nes 0 jau turi nustates i min/max
       if (A[i][i]>max) {
           i = max; // cia pakeiti indexa i max reiksme (siuo atveju visad taps A[0][0] reiksme). Turi pakeisti i ka nurodo max ir maxXY. max = A[i][i]; maxXY = i;
       }

       if (A[i][i] < min) {
           i = min; // ta pati klaida kaip su max
       }
   }
   r = A[min][min]; // ??
   A[min][min] = max; // A[minXY][minXY] = max;
   A[max][max] = min; // A[maxXY][maxXY] = min;
} // truksta pas tave

Redagavo Imago
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Turejau truputi laiko, tai parasiau siek tiek labiau "pazengusi" varianta naudojant pointerius.

#include <iostream>
#include <fstream>

using namespace std;

int main()
{
   ifstream In("../duom.txt");

   int m;
   In >> m;

   // sukuriam matrica
   int A[m][m];
   for (int i=0; i<m; i++)
       for (int j=0; j<m; j++)
           In >> A[i][j];
   In.close();

   // ieskom min ir max (idomi vieta)
   int * min = &A[0][0], * max = &A[0][0];
   for (int i=1; i<m; i++) {
       if (A[i][i] > *max)
           max = &A[i][i];

       if (A[i][i] < *min)
           min = &A[i][i];
   }

   // sukeiciam min ir max
   int tmp = *min;
   *min = *max;
   *max = tmp;

   // spausdinam nauja matrica
   for (int i=0; i<m; i++) {
       for (int j=0; j<m; j++)
           cout << A[i][j] << " ";
       cout << endl;
   }
}

 

Duomenys:

4
1 5 8 4
2 4 3 7
9 1 2 3
2 8 7 5

 

Rezultatas:

5 5 8 4
2 4 3 7
9 1 2 3
2 8 7 1

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