dfs 鏈式前向星速度在此秒殺vector

2021-07-31 02:02:15 字數 1038 閱讀 5339

題意:給你n個點的地圖,這個地圖由n-1條邊鏈結,那肯定是樹了,然後給你m個起點,問你從這m個起點出發到達1,路上消滅的叛軍數量。

題解:直接從1深搜,跑一邊地圖,回溯時,如果出現起點,那麼之前的叛軍全部消滅。

值得注意的是  vector的速度在這道題遠遠大於鏈式前向星。

以後慎用vector。。。

#include#include#include#include#include#include#include#include#define ll long long

#define x first

#define y second

#pragma comment(linker, "/stack:102400000,102400000")

using namespace std;

const int mod=11;

const int maxn=1e5+100;

int n,m,cnt;

ll ans;

int cost[maxn];

bool vis[maxn],book[maxn];

int head[maxn];

struct nodee[maxn*2];

void addedge(int u,int v)

bool dfs(int x)

if(book[v]) return true;

}return false;

}int main(){

int x,y;

cnt=0;

memset(vis,false,sizeof(vis));

memset(book,false,sizeof(book));

memset(head,-1,sizeof(head));

scanf("%d %d",&n,&m);

for(int i=1;i<=n;++i) scanf("%d",&cost[i]);

for(int i=1;i<=m;++i) scanf("%d",&x),book[x]=1;

for(int i=1;i

前向星和鏈式前向星

我們首先來看一下什麼是前向星.前向星是一種特殊的邊集陣列,我們把邊集陣列中的每一條邊按照起點從小到大排序,如果起點相同就按照終點從小到大排序,並記錄下以某個點為起點的所有邊在陣列中的起始位置和儲存長度,那麼前向星就構造好了.用len i 來記錄所有以i為起點的邊在陣列中的儲存長度.用head i 記...

前向星和鏈式前向星

前向星 前向星是一種特殊的邊集陣列,我們把邊集陣列中的每一條邊按照起點從小到大排序,如果起點相同就按照終點從小到大排序,並記錄下以某個點為起點的所有邊在陣列中的起始位置。鏈式前向星 鏈式前向星其實就是靜態建立的鄰接表,時間效率為o m 空間效率也為o m 遍歷效率也為o m next表示當前結點的下...

前向星和鏈式前向星

1 前向星 前向星是以儲存邊的方式來儲存圖,先將邊讀入並儲存在連續的陣列中,然後按照邊的起點進行排序,這樣陣列中起點相等的邊就能夠在陣列中進行連續訪問了。它的優點是實現簡單,容易理解,缺點是需要在所有邊都讀入完畢的情況下對所有邊進行一次排序,帶來了時間開銷,實用性也較差,只適合離線演算法。圖一 2 ...