спиральная матрица с использованием программы c

Я написал программу для печати матрицы в виде спирали, но она работает только для 3 * 3. как сделать его полезным для всех размеров.

#include<iostream.h>
#include<conio.h>
void main()
{
int i,j,k=1,l=0;
int n;
clrscr();
cout<<"Enter the number of row : ";
cin>>n;
int a[3][3];
cout<<"Matrix Form : "<<"\n";
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
a[i][j]=i*n+(j+1);
cout<<a[i][j]<<"\t";
}
cout<<"\n";
}
cout<<"Spiral form"<<"\n";
for(i=k;i<n;i++)
{
cout<<a[k][i]<<"\t";
}
k++;
for(i=k;i>=0;i--)
{
cout<<a[k][i]<<"\t";
}
k--;
for(i=k;i>=0;i--)
{
cout<<a[i][l]<<"\t";
}
for(i=k;i<n;i++)
{
cout<<a[l][i]<<"\t";
}

getch();
}

-2

Решение

Предполагая, что код работает, вам нужно действовать в этой строке:

int a[3][3];

Самый простой способ — использовать C ++ std::vector:

std::vector<std::vector<int> > a(n, std::vector<int>(n));

Запомни #include <vector> также.

0

Другие решения

Я попытался сгенерировать 3 * 3 спиральную матрицу, используя c, используя приращение и уменьшение строк и столбцов в массиве, затем выяснил сумму главных и противоположных диагоналей матрицы.
Мой код выглядит следующим образом

#include<stdio.h>
#define n 3
int main()
{
int m=n/2,i,j,a[10][10],c=1,sum=0,s=0;
for(i=m,j=m;j<n;j++)
{
a[i][j]=c;
c++;
}
j--;
i++;
while(j>=0)
{
a[i][j]=c;
c++;
j--;
}
i--;
j++;
a:
if(i>=0)
{
a[i][j]=c;
c++;
i--;
goto a;
}
i++;
j++;
b:
if(j<n)
{
a[i][j]=c;
c++;
j++;
goto b;
}
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
printf("\t%d",a[i][j]);

}printf("\n");
}
for (i = 0; i <n; i++)
{
sum = sum + a[i][i];
s=s+a[i][n-i-1];
}
printf("sum of diagonals is d1: %d d2: %d d1+d2: %d",sum,s,s+sum);
return 0;
}

выход:
нажмите здесь, чтобы посмотреть вывод

0

По вопросам рекламы [email protected]