栈与递归----链表与递归(2021年10月13日)

本文探讨如何写递归函数,强调了递归的基本项和归纳项,通过尾插法建链、求链表长度、链表输出和逆置等案例进行说明。此外,还深入讨论了八皇后问题,帮助读者深化对递归的理解。
摘要由CSDN通过智能技术生成

函数的嵌套调用
在这里插入图片描述可以再清晰一点看
在这里插入图片描述

如何写递归函数

第一步: 找到基本项(即终止条件)
递归的结束位置。
如果没有结束条件,则会出现运行栈满的情况。溢出
第二步: 归纳项(改变规模,类似

套娃)

以下涉及几个递归案例
1.尾插法建链、递归
2.求表长
3.链表输出
4.链表逆置

#include <iostream>
using namespace std;
struct Node
{
   
	int data;
	Node* link;
};

//尾插法建链、递归
Node* create(int n)
{
   
	if (n == 0) return 0;
	n--;
	Node* t = new Node;
	cin >> t->data;
	t->link = create(n);
	return t;
}

//求表长
//方法一: 用全局变量
int countnum;
void length1(Node * head)
{
   
	if (head == NULL)
		return ;
	countnum++;
	length1(head->link);
}

//方法二:  函数引用
void length2
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值