更多课程 选择中心

C/C++培训
达内IT学院

400-996-5531

C++递归实现螺旋数组的实例代码

  • 发布:C++培训
  • 来源:C++资讯
  • 时间:2020-06-01 15:34

本文主要介绍了C++递归实现螺旋数组的实例代码,代码简单易懂,非常不错,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下。如有其它问题,还请关注本站。

#include<iostream>

using namespace std;

//参数x表示开始元素的下标,m,n用于确定4条边尽头。

//a,b则用于判断是否可进行螺旋。p为二维数组。

void lx(int x,int m, int n, int a, int b, int **p);

int main()

{

//输入行列

int m = 0, n = 0;

cin >> m >> n;

int **a = new int*[m];

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

a[i] = new int[n];

a[0][0] = 1;

//调用lx函数

lx(0,m,n,m,n,a);

//输出螺旋数组

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

{

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

cout << a[i][j] << ' ';

cout << endl;

}

//别忘了删动态内存

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

delete []a[i];

delete[]a;

}

void lx(int x ,int m, int n,int a,int b,int **p)

{

//如果x不为0,则首元素的值为前一个元素值加一。

if (x)

p[x][x] = p[x][x - 1] + 1;

//完成四条边的赋值

for (int i = x+1; i < n; ++i)

p[x][i] = p[x][i - 1] + 1;

for (int j = x+1; j < m; ++j)

p[j][n - 1] = p[j - 1][n - 1] + 1;

if(a>1)

for (int i = n - 2; i >= x; --i)

p[m - 1][i] = p[m - 1][i + 1] + 1;

if(b>1)

for (int j = m - 2; j >= x+1; --j)

p[j][x] = p[j + 1][x] + 1;

//判断是否符合螺旋条件,从而判断是否调用lx函数

if ((a - 2 > 0) && (b - 2 > 0))

lx(x + 1,m - 1, n - 1,a-2,b-2, p);

}

调试

7 8

1 2 3 4 5 6 7 8

26 27 28 29 30 31 32 9

25 44 45 46 47 48 33 10

24 43 54 55 56 49 34 11

23 42 53 52 51 50 35 12

22 41 40 39 38 37 36 13

21 20 19 18 17 16 15 14

知识点扩展:

c++ 螺旋数递归实现

void printValue(int head,int x,int y,int n)

{

int NextHead = head + 4*n -4;

head = head -1;

if(x==n)

{

cout << (n+y-1)+head <<" ";

if(!head) cout<<endl;

}

else if(y == 1)

{

cout<< x + head<<" ";

}

else if(x==1)

{

cout << (4*n-2)-y +head<< " ";

}

else if(y==n)

{

cout << 3*n-1-x + head << " ";

}

else

{

printValue(NextHead,x-1,y-1,n-2);

}

}

void SpiralNumber(int n)

{

for (int y = 1;y<=n;y++)

{

for (int x = 1;x<=n;x++)

{

printValue(1,x,y,n);

}

}

}

总结

到此这篇关于C++递归实现螺旋数组的文章就介绍到这了,更多相关c++ 递归螺旋数组内容请请关注达内教育, 最后,达内c++培训机构提醒每一个it爱好者:如果你想要在短时间内快速入门,顺利掌握一门技术,建议还是认真学习视频。多练习,多动手。

版权声明:转载文章来自公开网络,版权归作者本人所有,推送文章除非无法确认,我们都会注明作者和来源。如果出处有误或侵犯到原作者权益,请与我们联系删除或授权事宜。

预约申请免费试听课

填写下面表单即可预约申请免费试听!怕钱不够?可就业挣钱后再付学费! 怕学不会?助教全程陪读,随时解惑!担心就业?一地学习,可全国推荐就业!

上一篇:C++生成随机数的实现代码
下一篇:C++编译/编辑器对OIer的必要功能

C语言宏定义的几种使用方法

C与C++内存管理避坑指南

C/C++代码规范注释有哪些讲究?

C语言中,全局变量滥用的后果竟如此严重?

Copyright © 2023 Tedu.cn All Rights Reserved 京ICP备08000853号-56 京公网安备 11010802029508号 达内时代科技集团有限公司 版权所有

选择城市和中心
黑龙江省

吉林省

河北省

湖南省

贵州省

云南省

广西省

海南省