Поиск простых цепей длины L

Revision ru1, by Tiny924, 2021-07-08 22:37:10

Всем привет! Нигде не могу найти как посчитать количество простых цепей длины L(или просто найти все простые цепи). Нашел только это, но как я понимаю для N = 100, этот способ в 4 секунды не уложится. Сам смог додуматься только до запуска dfs из каждой вершины и для каждого пути передать свой массив used:

void dfs(short int st, short int dist, vector<bool> used) {
	if (dist >= 7) {//В моей задаче нужно найти кол-во простых цепей длины 7
		++ans;
		return;
	}
	for (auto r : g[st]) {
		if (!used[r]) {
			used[r] = 1;
			dfs(r, dist + 1, used);
			used[r] = 0;
		}
	}
}

Спасибо за помощь!

Tags граф, dfs, цепей

History

 
 
 
 
Revisions
 
 
  Rev. Lang. By When Δ Comment
en2 English Tiny924 2021-07-08 23:45:53 2 Tiny change: '100 in fout seconds.\' -> '100 in four seconds.\'
en1 English Tiny924 2021-07-08 23:11:12 734 Initial revision for English translation
ru1 Russian Tiny924 2021-07-08 22:37:10 731 Первая редакция (опубликовано)