グラフの頂点の数として整数Nを入力しましたか?ランダムグラフの生成
- 1から10の範囲の各エッジにランダムウェイトを割り当てます。すべての可能なエッジはありません。 が存在します。上記の例のように、Xによって不在のエッジを表します。
- MとLがそれぞれ行列であり、生成する(同じ)ランダムグラフのリスト表現 を表すペア(M、L)を返します。
- エッジウェイトの混乱を避けるため、非数字の文字を頂点名として使用します。
#include <iostream>
#include <stdlib.h>
using namespace std;
void gen_random_graph(int n)
{
int adj_matrix[n][n];
for(int u = 0; u < n; u++)
{
for (int v = 0; v < n; v++)
{
if(adj_matrix[u][v]==adj_matrix[v][u])
{
adj_matrix[u][v] = rand() % 10 + 1;
cout << adj_matrix[u][v] << endl;
}
}
}
}
int main()
{
int N;
cout << "enter number of vertices" << endl;
cin >> N;
gen_random_graph(N);
return 0;
}
これは、これまでの私のコードです。それは体重を生成していますか?私はペアを返さなければならないということはどういう意味ですか?
まず、頂点はこの関数への入力です。したがって、その値を 'cin'を使ってコマンドラインの値に置き換えるべきではありません。この関数の外のコマンドラインから 'vertex'を更新し、コマンドラインから見つけたものを渡すべきです。 – NoseKnowsAll