旋转矩阵算法

QUESTION:

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

void func(int n)

要求:通过传入的n,输出一个4*4的矩阵, 顺序如上图所示. 

 

CODE:

//NXN矩阵
#include <iostream>
using namespace std;
#include <iomanip>
//#define MAXSIZE 4
    //全局变量
  int value;

void right();          //向左输入的赋值函数
void down();
void left();
void up();
void show();          //显示函数
void sort();          //控制方向的函数
 int direction = 0;     //控制方向
int rightNum = 0;      //向左输入一行的次数
int downNum = 0;   
int leftNum = 0; 
int upNum = 0;     
int arrayNum = 0;       //自增赋值数
int row = 0;           //保存行下标
int col =0;            //保存列下标
int array[100][100];    //保存数组

int main()
{
cin>>value;
 
sort();
show();
return 0;
}

 

void sort()
{

//while(arrayNum <= value*value)
//{
while(arrayNum != value*value)   //循环跳出条件,赋值完毕
{
switch(direction)
{
case 0:
    right();
break;
case 1:

down();
break;
case 2:

left();
break;
case 3:
 
up();
break;

default:
break;
}
}

return;
}

void right()
{
int m = row;
int n = col;
if(m==0&&n==0)
{
array[m][n] = ++arrayNum;
}
for(int i=n+1; i<value-rightNum;i++)
{
array[m][i] = ++arrayNum;
n++;
}
row=m;
col=n;
rightNum++;
direction = 1;
return;
}

void down()
{
int m = row;
int n = col;

for(int i=m+1; i<value-downNum;i++)
{
array[i][n] = ++arrayNum;
m++;
}
row=m;
col=n;
downNum++;
direction = 2;
return;
}

void left()
{
int m = row;
int n = col;

for(int i=n-1; i>=leftNum;i--)
{
array[m][i] = ++arrayNum;
n--;
}
row=m;
col=n;
leftNum++;
direction = 3;
return;
}

void up()
{
int m = row;
int n = col;

for(int i=m-1; i>upNum; i--)
{
array[i][n] = ++arrayNum;
m--;
}
row=m;
col=n;
upNum++;
direction = 0;
return;
}

void show()
{
int n =0;
for(int i=0; i<value; i++)
{
for(int j=0; j<value; j++)
{
cout<<setw(value)<<array[i][j];
}
 cout<<endl;
}
}

本人经过几年的努力,终于掌握了C#的编程,与同学一起开发了这套软件。与各位网友共勉。 1.5版正式推出!主要修正了(以下都是重大问题所以应及时更新,对给您造成的不便,本公司深表歉意): 1、重装软件后提示30天试用期已过的BUG; 2、机器码和注册码的0和字母O不好区分的问题。 3、一个注册表错误,会使软件重启后当成试用期结束。 “世间能有几回运,彩票游戏存玄机” ,也许您会有疑问:彩票开奖号码不是完全随机的吗?那我还算什么,随便写几个数字买算了!!其实您错了,世界上并没有绝对理想的随机数,就算是用电脑也只能产生接近随机的数:在彩票开奖产生号码时,诸如摇奖机的物理特性、每个球的重量和光滑度的差异、空气的流动性等等都会使开奖结果产生一定的偏态,在中短期内有一定的规律可寻。 那么怎样才能找出偏态,利用偏态提高中奖的概率呢?用手工显然不行,您需要一款称手软件!但是现在彩票软件多得让人眼花缭乱,哪个才是适合您的呢?得彩易彩票旋转矩阵选号杀号王双色球专用版的问世,解决了您的烦恼,您只要下载使用了,软件就会主动成为您的好帮手,让您中奖不再是梦想! 本公司双色球项目开发小组根据组里多名长年研究彩票双色球的专家的成果,经过反复的概率验证,精心设计了算法,其中大部分属于本公司原创独有。程序运行时随着期数的增加,出号趋势会愈发明显,算法也会愈发准确,一般开奖期数在最近50-150期时效果最为明显。 友情提示:彩票软件可以帮您提高中奖的概率,但并不能保证您100%中大奖,本软件也不例外!如果有所谓专家向您推荐号码并保证能中大奖的,请您一定要当心受骗! 1、本软件基于微软.net框架进行开发,技术先进。 2、市面上的一般彩票软件所提供的旋转矩阵只有廖廖几个方案(如保6中5,保5中4),本软件则提供了几十种方案,应有尽有。 3、选号杀号功能的强大和全面是其它一般彩票软件所没有的。 4、过滤功能全面,完全可以满足需要。 5、开奖数据可以更新,导入和导出,极大的方便彩民朋友。 6、学习容易,帮助文档详尽,上手极快。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值