用C++实现顺时针增加的螺旋队列

<img src="" alt="" />
#include<iostream>
using namespace std;
int a[10][10];
void foo(int n)
{
	int m=1;
	int i,j;
	for(i=0;i<n/2;++i)
	{
		for(j=0;j<n-i;++j)
		{
			if(a[i][j]==0)
				a[i][j]=m++;
		}
		for(j=i+1;j<n-i;++j)
		{
			if(a[j][n-i-1]==0)
				a[j][n-i-1]=m++;
		}
		for(j=n-i-1;j>i;j--)
		{
			if(a[n-i-1][j]==0)
			{
				a[n-i-1][j]=m++;
			}
		}
		for(j=n-i-1;j>i;--j)
		{
			if(a[j][i]==0)
				a[j][i]=m++;
		}
	}

}
int main()
{
	for(int i=0;i<5;++i)
    {
		for(int j=0;j<5;++j)
			a[i][j]=0;

    }
	foo(5);
	for(int i=0;i<5;++i)
    {
		for(int j=0;j<5;++j)
			cout<<a[i][j]<<'\t';
		cout<<endl;
    }
    system("pause");
	return 0;
}

时间: 2024-08-05 22:11:22

用C++实现顺时针增加的螺旋队列的相关文章

螺旋队列顺时针方向 和逆时针方向的实现

这个博主找规律的部分写得很好,原样放在下面.最后给出了顺时针和逆时针方向的螺旋队列的实现,可以看出它们的差别如此之小. 和螺旋队列类似,也是找规律的zigzag数组见这个帖子. 螺旋队列的样子如下图: 两大规律: 1.螺旋规律 2.奇数(圈数,或X轴正坐标)平方规律(紫线) 问题描述: 设1的坐标是(0,0),x方向向右为正,y方向向下为正,例如,7的坐标为(-1,-1),2的坐标为(1,0).编程实现输入任意一点坐标(x,y),输出所对应的数字! 问题解决: 从紫线突破. 从图中不难发现,每圈

螺旋队列问题

1 #include<iostream> 2 #include<iomanip> 3 using namespace std; 4 #define max(a,b) ((a)>(b) ? (a) : (b)) 5 #define abs(a) ((a)>0 ? (a) : (-a)) 6 int foo(int x, int y) 7 { 8 int t = max(abs(x),abs(y)); 9 int v; 10 int u = 2 * t -1; 11 u =

顺时针和逆时针螺旋打印二维数组(行列式)

一.要求: 行列式,行和宽不一定相等,要求顺时针螺旋打印每一个元素,所谓顺时针螺旋即: 第一圈:从第一行第一列元素开始,先从左到右打印第一行所有元素,接着打印最后一剩余列元素,再从右到左打印最后一行剩余元素,接着从下到上打印第一列剩余元素 第二圈:从第二行第二列开始,按上面的顺时针顺序打印一圈元素 ...,一圈圈反复,直到把所有元素无重复的打印完. 逆时针螺旋与上面的顺序刚好相反. 二.分析: 顺时针螺旋打印可以将问题分割为:先按顺时针打印第一圈,再按顺时针打印第二圈,其中每圈又分四个步骤:从左

螺旋队列

螺旋矩阵:要求输入(x,y),输出螺旋矩阵中相应的元素. int printfSpiralMatrix(int x,int y) { int Max = abs(x) > abs(y) ? abs(x) : abs(y); int Result; if (Max == x) // x 正半轴 { if (Max == -y) //会突变 Result = pow((Max * 2 + 1), 2); else Result = pow((Max * 2 - 1), 2) + Max + y; }

螺旋队列问题之二

如矩阵 1 2 3 4 5 16 17 18 19 6 15 24 25 20 7 14 23 22 21 8 13 12 11 10 9 找出规律,并打印出一个N*N的矩阵:规律就是从首坐标开始顺时针增大,所以 1.需要一个变量m来递增记录进度. 2.注意各个转折点. 具体代码实现如下: #include <stdio.h> #define N 5 int a[N][N]={0}; void fun(int n) { int i,j; int m=1; for(i=0;i<n/2;i+

螺旋队列和hiho1525逃离迷宫3

我是真调不出错误了! hiho1525逃离迷宫3 #include <stdio.h> #include <stdlib.h> #include <math.h> //中间变量为长整形,so x,y变量一定要设置为长整型 long long cal(long long x,long long y) { if (x<=y && y<=-x && x<=0) return (4*x*x-3*x+y)%26; else if

Disruptor——一种可替代有界队列完成并发线程间数据交换的高性能解决方案

本文翻译自LMAX关于Disruptor的论文,同时加上一些自己的理解和标注.Disruptor是一个高效的线程间交换数据的基础组件,它使用栅栏(barrier)+序号(Sequencing)机制协调生产者与消费者,从而避免使用锁和CAS,同时还组合使用预分配内存机制.缓存行机制(cache line).批处理效应(batch effect)来达到高吞吐量和低时延的目标.目前Disruptor版本已经迭代至3.0,本论文是基于Disruptor1.0写就,在新版本中,相对与1.0版本,其核心设计

消息队列最大数目

消息队列: 1.每次msgrcv一个消息,1.那个消息会在内核中移除 2.每次msgrcv都只会给一个消息出来,不管你rcv用多大的buf来接收,都是可以的.如果msgrcv的bufSize小于实际的该消息的大小,那么可以设置一个标志:表示截断. 如果不设置,那么会报错.取不出来. 2.消息满了,则默认0为阻塞,直到有了空间位置,才能snd消息进入到内核. 消息空了,则默认为0阻塞,直到有了一个消息位置,才能 rcv消息进入到进程内存. 3.如果指定msgflg:MSG_NOERROR,如果函数

【Java并发编程实战】—– AQS(四):CLH同步队列

在[Java并发编程实战]-–"J.U.C":CLH队列锁提过,AQS里面的CLH队列是CLH同步锁的一种变形. 其主要从双方面进行了改造:节点的结构与节点等待机制.在结构上引入了头结点和尾节点,他们分别指向队列的头和尾,尝试获取锁.入队列.释放锁等实现都与头尾节点相关.而且每一个节点都引入前驱节点和后兴许节点的引用:在等待机制上由原来的自旋改成堵塞唤醒. 其结构例如以下: 知道其结构了,我们再看看他的实现.在线程获取锁时会调用AQS的acquire()方法.该方法第一次尝试获取锁假设