#include <cstdio>
#include <cstring>
#include <string>
#include <algorithm>
#include <iostream>
#include <map>
#include <queue>
#include <cmath>
#include <vector>
using namespace std;
typedef long long ll;
const int N=1e5+7;
int head[N];
int cnt;
struct node
{
int next;//前一个节点
int to;//这条边的终点
}edge[N<<1];
void add(int u,int v)
{
edge[cnt].to=v;
edge[cnt].next=head[u];
head[u]=cnt++;
}
int main()
{
cnt=0;
int n;
cin>>n;
for(int i=0;i<n;i++)
head[i]=-1; //初始化 -1 表示当前边为最开始的边,之前没有边
//遍历以p为起点的所有边
int p;
cin>>p;
for(int i=head[p];i!=-1;i=edge[i].next)
{
//对于程序来说是指向下一条边,但是对于输入来说,是指向前一条边
}
}
//edge[cnt].to=a edge[cnt].next=b head[p]=cnt
//表示 路径 p 到 a 即 edge[head[p]].to=a;
//k的前一个与之相连的点(按照输入顺序)是 b
链式前向星
最新推荐文章于 2025-02-07 19:13:19 发布