环形队列的输出_输出循环队列.

C/C++ code#include

#include

#include

#define TABLE_ROW 100

#define TABLE_COL TABLE_ROW

static int aTable[TABLE_ROW][TABLE_COL]={0};

static int aDirect[4][2]=

{

{0,1},{1,0},{0,-1},{-1,0}

};

/*

21 22 ....

21 7 8 9 10

19 6 1 2 11

18 5 4 3 12

17 16 15 14 13

*/

int main()

{

int iRow,iCol,iNum;

int iStep,iCntStep;

int iDir,iCntDir;

int iTopRow=-1,iTopCol=TABLE_COL,iBotRow,iRightCol=-1;

scanf("%d",&iNum);

iRow=iCol=(int)sqrt(1.0*iNum);

iStep=1;

iCntStep=iDir=iCntDir=0;

for(int iCnt=0;iCnt!=iNum;++iCnt)

{

aTable[iRow][iCol]=iCnt+1;

if(iCntStep==iStep)

{

//change direction

iDir=(iDir+1)%4;

iCntStep=0;

iCntDir++;

if(iCntDir==2)

{

iCntDir=0;

iStep++;

}

}

iCntStep++;

iRow+=aDirect[iDir][0];

iCol+=aDirect[iDir][1];

}

//找打印范围

for(int iR=0;iR

{

bool bHas=false;

for(int iC=0;iC

{

if(aTable[iR][iC]!=0)

{

bHas=true;

iBotRow=iR; //最低行

if(iTopRow==-1)

{

iTopRow=iR; //最高行

}

if(iC

{

iTopCol=iC; //最左列

}

}

else if(aTable[iR][iC]==0 && bHas)

{

if(iC>iRightCol)

{

iRightCol=iC;

}

break;

}

}

}

for(int iR=iTopRow;iR<=iBotRow;++iR)

{

bool bPrtLn=false;

for(int iC=iTopCol;iC

{

if(aTable[iR][iC]==0)

{

printf(" ");

}

else

{

bPrtLn=true;

printf("%3d",aTable[iR][iC]);

}

}

if(bPrtLn)

{

printf("\n");

}

else

{

break;

}

}

return 0;

}

79

73 74 75 76 77 78 79

72 43 44 45 46 47 48 49 50

71 42 21 22 23 24 25 26 51

70 41 20 7 8 9 10 27 52

69 40 19 6 1 2 11 28 53

68 39 18 5 4 3 12 29 54

67 38 17 16 15 14 13 30 55

66 37 36 35 34 33 32 31 56

65 64 63 62 61 60 59 58 57

请按任意键继续. . .

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值