基本上我生成了一個adj_matrix,我想從adj_matrix做一個adj_list ...但是我總是收到一個錯誤,說「不匹配的呼叫...」 我試了它沒有aPair我仍然得到同樣的錯誤,我似乎無法弄清楚我的問題是什麼。誰能告訴我爲什麼列表不起作用?該列表是在代碼的最後鄰接列表錯誤與列表
int **gen_random_graph(int n)
{
srand(time(0));
int **adj_matrix = new int*[n];
for(int i = 0; i < n; i++)
{
for (int j = i; j < n; j++) //generating a N x N matrix based on the # of vertex input
{
adj_matrix[i] = new int[n];
}
}
for(int u = 0; u < n; u++)
{
for (int v = u; v < n; v++)
{
bool edgeOrNot = rand() % 2; //decide whether it has an edge or not
adj_matrix[u][v] = adj_matrix[v][u] = edgeOrNot;
if(adj_matrix[u][v] == true)
{
adj_matrix[v][u] = true;
if(u == v) //We can't have i = j in an undirected graph so we set it to false
{
adj_matrix[u][v] = -1;
}
}
else //if adj_matrix[u][v] is false set the symmetry to be false
{
adj_matrix[v][u] = adj_matrix[u][v] = -1;
}
}
}
for(int i = 0; i < n; i++)
{
for(int j = i; j < n; j++) //create the N x N with edges and sets the weight between the edge randomly
{
if(adj_matrix[i][j] == true)
{
int weight = rand() % 10 + 1;
adj_matrix[i][j] = adj_matrix[j][i] = weight;
cout << " (" << i << "," << j << ") " << "weight: " << adj_matrix[i][j] << endl;
}
}
}
for(int i = 0; i < n; i++)
{
vector<int> adj_list;
for(int j = i; j < n; j++)
{
if(adj_matrix[i][j] > 0)
{
int weight = adj_matrix[i][j];
adj_list.push_back(j);
cout << adj_list[i] << " " << endl;
}
}
}
print(n,adj_matrix);
return (adj_matrix);
}
可以調用adj_list嗎? –
umm我沒有爲adj_list做一個函數,所以我不認爲它可以被調用。基本上我生成了一個adj_matrix,現在從形式矩陣我必須創建adj_list – Darkflame
嗯,但我只需要從adj_matrix [i] [j]的權重有沒有辦法解決這個問題? – Darkflame