【发布时间】:2012-08-25 10:54:48
【问题描述】:
我想更改以下控制台应用程序的堆栈大小:
using System;
using System.IO;
class Test {
static int n;
static bool[] us;
static int[,] matr;
static void dfs(int a) {
us[a] = true;
for (int b = 0; b < n; b++) {
if (!us[b]) {
dfs(b);
}
}
}
static void Main() {
StreamReader input = new StreamReader("input.txt");
StreamWriter output = new StreamWriter("output.txt");
string[] snum = input.ReadLine().Split(' ');
n = int.Parse(snum[0]); // number of vertices
int m = int.Parse(snum[1]); // number of edges
us = new bool[n];
matr = new int[n, n];
for (int i = 0; i < m; i++) {
snum = input.ReadLine().Split(' ');
int a = int.Parse(snum[0]) - 1, b = int.Parse(snum[1]) - 1;
matr[a, b] = matr[b, a] = 1;
}
for (int i = 0; i < n; i++) {
if (!us[i]) {
dfs(i);
}
}
input.Close();
output.Close();
}
}
当n 近似时。 100,000,dfs 的深度约为。 100,000 并且应用程序抛出 StackOverflowException。
我知道默认堆栈大小是 1 MB,但我不知道如何更改它。
【问题讨论】:
-
考虑在没有方法递归的情况下实现 dfs
-
为什么 dfs 还是递归的?将所有值设置为某个索引到
true,这看起来像是一种过于昂贵的方法。 -
实际上它只是 DFS - 考虑图形的其他有用算法的基础。我认为只有 DFS 会是更清晰的递归示例。
标签: c# stack-overflow stack-size