Selecting a random neighbor
data:image/s3,"s3://crabby-images/a5ae7/a5ae7e94b7906993f512c17da349b9b6e0709ab9" alt=""
Hi, I'm totally new to BGL. I would like to know what is the best way to select a random neighbor of a vertex in an undirected graph without having to iterate through all neighbors. Can anyone help me with that? Thanks! George. -- George Bezerra Doctoral Student Department of Computer Science University of New Mexico, USA
data:image/s3,"s3://crabby-images/e5702/e570265f900a3b9564b22189d72b1c797ca0217f" alt=""
On Tue, 20 Dec 2011, George Bezerra wrote:
Hi, I'm totally new to BGL. I would like to know what is the best way to select a random neighbor of a vertex in an undirected graph without having to iterate through all neighbors. Can anyone help me with that? Thanks!
There is an out_degree() function you can call, then use a random number from 0 to that value to index a particular outgoing edge. Use std::advance for counting to take advantage of out_edge_iterator types that directly support random access (not all do). -- Jeremiah Willcock
participants (2)
-
George Bezerra
-
Jeremiah Willcock