程序员面试之循环与递归(四)

递归

        递归调用的框架图

        

        递归关注的因素:退出条件、递归的参数有哪些、递归的返回值、局部变量、全局变量、合适输出、会不会出现栈溢出。

        递归调用一定包括:① 递归调用部分,② 递归停止条件,③ 递归返回值(注意:递归可以有多个结束条件)

        递归的缺陷:效率低、递归的层次太深,容易导致栈溢出。

        例子:统计字符串中第一次出现的空格前的字符个数。

int callen(char* str){
	if (str[0] == ' '){
		return 0;
	}else{
		return callen(str+1)+1;
	}
}

循环

        用C++,实现一个螺旋队列,如下图
        
const int MaxLen = 8;
void ScrewArray(int iDubArr[][MaxLen])
{
	int iM = 0;
	for (int iTotal=0; iTotal<=MaxLen/2; iTotal++)
	{
		int iRow,iCol;
		//move right
		for (iRow=iTotal; iRow<MaxLen-iTotal; iRow++)
		{
			iDubArr[iTotal][iRow] = iM++;
		}
		
		//move down
		for (iCol=iTotal+1; iCol<MaxLen-iTotal; iCol++)
		{
			iDubArr[iCol][iRow-1] = iM++;
		}
		
		//move left
		for (iRow=MaxLen-iTotal-2; iRow>=iTotal; iRow--)
		{
			iDubArr[iCol-1][iRow] = iM++;
		}
		
		//move up
		for (iCol=MaxLen-iTotal-2; iCol>iTotal; iCol--)
		{
			iDubArr[iCol][iRow+1] = iM++;
		}
	}
}

int main()
{
	
	int iDubArr[MaxLen][MaxLen]={0};
	ScrewArray(iDubArr);
	
	for (int i=0; i<MaxLen; i++)
	{
		for (int j=0; j<MaxLen; j++)
		{
			printf("%d\t",iDubArr[i][j]);
		}
		printf("\n");
	}
	
	return 0;
}



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值