前提・実現したいこと
頂点の数を入力し無向グラフをランダムに生成し、そのグラフを接続行列で出力したいです。
発生している問題・エラーメッセージ
元々ランダムに生成された無向グラフを隣接行列と隣接リストに出力するプログラムを、 接続行列を出力する(列:辺数、行:頂点数で、各列の和が2になる)よう書き換えたのですが、以下の実行結果のように出力されてしまいます。 頂点数 = 5 グラフの辺数 = 7 0 1 1 1 1 0 0 1 1 1 0 1 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 0 0 0 0 0 0
該当のソースコード
#include <iostream> #include <vector> #include <algorithm> #include <list> #include <random> using namespace std; bool graph[1010][1010]; class con_matrix { private: vector < vector<int>> matrix; public: con_matrix(int vn, int en) { set_vertex_num(vn, en); } void set_vertex_num(int vn, int en) { matrix.resize(vn); //行列行数を設定 for (auto& line : matrix) line.resize(en); //行列列数を設定 } int get_vertex_num() const { return matrix.size(); } int get_edge_num() const { return matrix.at(0).size(); } void set_random(unsigned int seed = 0) // seed:乱数シード(値を変えると乱数列が変化) { for (auto& row : matrix) { for (auto& v : row) v = 0; //要素をクリア } int vn = matrix.size(); //頂点数 int en = matrix.at(0).size(); //辺数 srand(seed); for (int cnt = 0; cnt < vn; ) { int r1 = rand() % vn; int r = 0; for (int a = 0; a < 2; ) { int r2 = rand() % vn; if (r != r2 && !matrix[r1][r2]) { r = r2; matrix[r1][r2] = 1; a++; } } cnt++; } } void disp_connection() const { for (auto& row : matrix){ for (auto v : row) cout << v << " "; //要素を表示 cout << endl; //行列列数を設定 } } int connection(int i, int j) const { return matrix[i][j]; } void make_con_list(vector<vector<int>>& al) const { int vn = matrix.size(); //頂点数 al.resize(vn); for (int i = 0; i < vn; i++) { al[i].resize(0); for (int j = 0; j < vn; j++) { if (connection(i, j)) al[i].push_back(j); } } } }; void disp_adj_list(const vector<vector<int>>& al) { for (auto& list : al) { for (auto v : list) { cout << v << " "; //行列列数を設定 } cout << endl; //行列列数を設定 } } int main() { const int n = 5; //頂点数 double r = 0.7; //辺数の比率 const int e = ((n * (n - 1) / 2) * r); int cover = 0; // 被覆数 con_matrix am(n, e); //接続行列 am.set_random(1); //ランダムにグラフの隣接行列を作る。引数は辺の存在確率, 乱数シード cout << "頂点数 = " << n << endl; cout << "グラフの辺数 = " << e << endl; am.disp_connection(); cout << endl; vector<vector<int>> ajl; //隣接リスト // am.make_con_list(ajl); disp_adj_list(ajl); return 0; }
試したこと
以下のプログラムにある、int r1 = rand() % vn や cnt < vn を辺数である en に書き換えたりすると実行不可となり、出力すらできなくなります。
補足情報(FW/ツールのバージョンなど)
visual studio 2019のC++言語で入力しています。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2021/11/06 05:05