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
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';
}
}
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
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;
}
#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
Matematică,
8 ani în urmă
Limba română,
8 ani în urmă
Matematică,
8 ani în urmă
Matematică,
9 ani în urmă
Matematică,
9 ani în urmă
Limba română,
9 ani în urmă
Limba română,
9 ani în urmă
Limba română,
9 ani în urmă