程序员面试之循环与递归(四)
来源:互联网 发布:网络防伪查询系统 编辑:程序博客网 时间:2024/05/16 18:36
递归
递归调用的框架图
递归关注的因素:退出条件、递归的参数有哪些、递归的返回值、局部变量、全局变量、合适输出、会不会出现栈溢出。
递归调用一定包括:① 递归调用部分,② 递归停止条件,③ 递归返回值(注意:递归可以有多个结束条件)
递归的缺陷:效率低、递归的层次太深,容易导致栈溢出。
例子:统计字符串中第一次出现的空格前的字符个数。
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 rightfor (iRow=iTotal; iRow<MaxLen-iTotal; iRow++){iDubArr[iTotal][iRow] = iM++;}//move downfor (iCol=iTotal+1; iCol<MaxLen-iTotal; iCol++){iDubArr[iCol][iRow-1] = iM++;}//move leftfor (iRow=MaxLen-iTotal-2; iRow>=iTotal; iRow--){iDubArr[iCol-1][iRow] = iM++;}//move upfor (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 0
- 程序员面试之循环与递归(四)
- 面试之路(23)-递归和循环优缺点详解
- 程序员面试宝典之数据结构基础---⑤单链表逆序的递归与非递归实现
- JavaScript的递归之递归与循环
- java之递归循环与递归
- 程序员面试宝典笔记3--循环递归概率
- 程序员面试宝典--8.2递归(1)
- 程序员面试宝典--8.2递归(2)
- 递归问题与递归结构(四)
- 程序员面试之道(《程序员面试笔试宝典》)之如何与企业进行待遇谈判?
- 程序员面试之道(《程序员面试笔试宝典》)之如何与企业进行待遇谈判?
- 程序员面试之道(《程序员面试笔试宝典》)之如何与企业进行待遇谈判?
- Java面试之斐波纳契数列递归与非递归实现
- Java面试之斐波纳契数列递归与非递归实现
- 【程序员面试宝典】递归之两个字符串连接次序问题(P83)
- 《程序员面试宝典-第四版》之递归学习
- 程序员面试宝典之数据结构基础----循环链表(约瑟夫环问题)
- 程序员面试100题之十一:数组循环移位
- Android开发之Android 5.0新特性
- linux内核定时器编程
- Session的生命周期
- php 与 java socket通信问题
- SQL行转列汇总--通用方法
- 程序员面试之循环与递归(四)
- Mysql的jdbc.properties模板
- Java读取war包文件
- iOS开发系列—Objective-C之Foundation框架
- Java IO详解
- iOS开发之CAAnimation核心动画
- spring配置文件模板
- QT的进程与线程
- 在IE下label标签图片下隐藏的单选按钮radio不起作用解决办法