Informatică, întrebare adresată de adelina122qmea, 9 ani în urmă

Scrieţi un program care citeşte de la tastatură un număr natural n şi construieşte în memorie o matrice cu 2*n linii şi 2*n coloane, numerotate de la 1 la 2*n, astfel încât parcurgând doar liniile impare ale matricei de sus în jos şi fiecare linie impară de la stânga la dreapta se obţin în ordine strict crescătoare toate numerele impare cuprinse în intervalul [1,4*n*n], iar parcurgând doar liniile pare ale matricei de sus în jos şi fiecare linie pară de la dreapta la stânga se obţin în ordine strict crescătoare toate numerele pare cuprinse în intervalul [1,4*n*n].
Date de intrare
Programul citește de la tastatură numărul n.

Date de ieşire
Programul afișează pe ecran matricea construită, câte o linie a matricei pe câte o linie a ecranului, elementele fiecărei linii fiind separate prin câte un spaţiu.

Restricţii şi precizări
2≤n≤10
Exemplu
Intrare

2
Ieșire

1 3 5 7
8 6 4 2
9 11 13 15
16 14 12 10

Răspunsuri la întrebare

Răspuns de Razzvy
2
#include <iostream>
using namespace std;
int main(){    i
     int a[20][20], n, cnt;   
     cin>>n;   
     cnt = 1;   
     //Vom parcurge mai inatai liniile impare si apoi pe cele pare   
     for(int i = 0; i < 2 * n; i += 2)       
          for(int j = 0; j < 2 * n; ++j){           
               a[i][j] = cnt;           
               cnt += 2;       
          }   
     cnt = 2;   
     //Aici parcurgem liniile de la dreapta la stanga   
     for(int i = 1; i < 2 * n; i += 2)       
          for(int j = 2 * n - 1; j >= 0; --j){           
               a[i][j] = cnt;           
               cnt += 2;   
          }   
     //afisare   
     for(int i = 0; i < 2 * n; ++i){       
          for(int j = 0; j < 2 * n; ++j){           
               cout<<a[i][j]<<' ';       
          }       
          cout<<'\n';   
     }
}

blindseeker90: Razzvy, poti sa folosesti toolul lui artur ca sa aranjezi frumos in comentariu liniile de cod http://www.artur99.net/brfix/
Răspuns de blindseeker90
2
Asta e o varianta in care parcurgi direct toata matricea si iei decizia in functie de linia pe care te afli

#include <iostream>
#include <cmath>
using namespace std;

int main(){
int n,i,j,a[100][100];
cin>>n;
for(i=0;i<2*n;i++){
for(j=0;j<2*n;j++){
if(i%2==0){
a[i][j]=(i/2)*4*n+2*(j+1)-1;
}
else{

a[i][j]=((i-1)/2)*4*n+2*(2*n-j);
}
}
}
for(i=0;i<2*n;i++){
for(j=0;j<2*n;j++){
cout<<a[i][j]<<" ";
}
cout<<endl;
}

return 0;
}
Alte întrebări interesante