<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://mywikibiz.com/index.php?action=history&amp;feed=atom&amp;title=Directory%3ADerek_Elder%2FPrograms%2FReachable</id>
	<title>Directory:Derek Elder/Programs/Reachable - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://mywikibiz.com/index.php?action=history&amp;feed=atom&amp;title=Directory%3ADerek_Elder%2FPrograms%2FReachable"/>
	<link rel="alternate" type="text/html" href="https://mywikibiz.com/index.php?title=Directory:Derek_Elder/Programs/Reachable&amp;action=history"/>
	<updated>2026-06-18T14:13:01Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.35.3</generator>
	<entry>
		<id>https://mywikibiz.com/index.php?title=Directory:Derek_Elder/Programs/Reachable&amp;diff=96706&amp;oldid=prev</id>
		<title>Derek Elder: +Program</title>
		<link rel="alternate" type="text/html" href="https://mywikibiz.com/index.php?title=Directory:Derek_Elder/Programs/Reachable&amp;diff=96706&amp;oldid=prev"/>
		<updated>2009-11-02T23:07:03Z</updated>

		<summary type="html">&lt;p&gt;+Program&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;lt;pre&amp;gt;&lt;br /&gt;
//Program 1c&lt;br /&gt;
//Professor Pattis, ICS-23 Lab 1&lt;br /&gt;
//Programmers: Cameron Ruatta, Derek Elder&lt;br /&gt;
&lt;br /&gt;
import edu.uci.ics.pattis.introlib.Prompt;&lt;br /&gt;
import edu.uci.ics.pattis.introlib.TypedBufferReader;&lt;br /&gt;
import edu.uci.ics.pattis.ics23.collections.*;&lt;br /&gt;
&lt;br /&gt;
import java.util.Iterator;&lt;br /&gt;
import java.util.StringTokenizer;&lt;br /&gt;
import java.io.EOFException;&lt;br /&gt;
&lt;br /&gt;
//Example of how this code works:&lt;br /&gt;
//Say we have a node a that points to node b and c&lt;br /&gt;
//Add a to searchNodes queue, pass it to reachable(), reachable() removes a from the queue and adds it's destination nodes to a set&lt;br /&gt;
//Destination nodes b and c are passed to reachable() and their destination nodes are added to searchNodes and destination nodes.&lt;br /&gt;
&lt;br /&gt;
public class Reachable&lt;br /&gt;
{&lt;br /&gt;
	public static Set&amp;lt;String&amp;gt; reachableNodes = new ArraySet&amp;lt;String&amp;gt;();&lt;br /&gt;
	public static Queue&amp;lt;String&amp;gt; searchNodes = new ArrayQueue&amp;lt;String&amp;gt;();&lt;br /&gt;
	&lt;br /&gt;
	public static void printGraph(Map&amp;lt;String,Set&amp;lt;String&amp;gt;&amp;gt; graphMap, String output)&lt;br /&gt;
	{&lt;br /&gt;
		System.out.println(output);&lt;br /&gt;
		List&amp;lt;String&amp;gt;sourceNodesList = new ArrayList&amp;lt;String&amp;gt;(graphMap.keys());&lt;br /&gt;
		for(String sourceNode : sourceNodesList)&lt;br /&gt;
		{&lt;br /&gt;
			Set&amp;lt;String&amp;gt; destinationNodes = graphMap.get(sourceNode);&lt;br /&gt;
			System.out.println(sourceNode + &amp;quot; -&amp;gt; &amp;quot; + destinationNodes);&lt;br /&gt;
		}&lt;br /&gt;
	}&lt;br /&gt;
	public static boolean existsIn(String s, Iterable&amp;lt;String&amp;gt; v)&lt;br /&gt;
	{&lt;br /&gt;
		//This method allows us to see if an Iterable data type (ArrayQueue &amp;amp; ArraySet) has string s in it already.&lt;br /&gt;
		//It returns boolean true if the string is already present.&lt;br /&gt;
		Iterator&amp;lt;String&amp;gt; it = v.iterator();&lt;br /&gt;
		Boolean toAdd = false;&lt;br /&gt;
		while(toAdd == false &amp;amp;&amp;amp; it.hasNext())&lt;br /&gt;
		{&lt;br /&gt;
			if(it.next().equals(s))&lt;br /&gt;
				toAdd = true;&lt;br /&gt;
		}&lt;br /&gt;
		return toAdd;&lt;br /&gt;
	}&lt;br /&gt;
	public static Set&amp;lt;String&amp;gt; reachable(Map&amp;lt;String,Set&amp;lt;String&amp;gt;&amp;gt; graphMap, String startNode)&lt;br /&gt;
	{&lt;br /&gt;
		if(existsIn(startNode, reachableNodes) == false) //Check and see if startNode is already in reachableNodes&lt;br /&gt;
		{&lt;br /&gt;
			reachableNodes.add(startNode);&lt;br /&gt;
		}&lt;br /&gt;
		&lt;br /&gt;
		while(!searchNodes.isEmpty()) //While there are nodes in searchNodes&lt;br /&gt;
		{&lt;br /&gt;
			for(String e : searchNodes) &lt;br /&gt;
			{&lt;br /&gt;
				try&lt;br /&gt;
				{&lt;br /&gt;
					searchNodes.remove(); //Remove the current node to prevent repeat searches&lt;br /&gt;
					Set&amp;lt;String&amp;gt; destinationNodes = new ArraySet&amp;lt;String&amp;gt;(graphMap.get(e));&lt;br /&gt;
					for(String i : destinationNodes) //Go through destinations of node e&lt;br /&gt;
					{&lt;br /&gt;
						if(existsIn(i, searchNodes)==false) //Check to see if a destination node already is going to be searched later&lt;br /&gt;
							searchNodes.add(i); //Add in all the new destination nodes of e into searchNodes to be searched next&lt;br /&gt;
					}&lt;br /&gt;
					reachable(graphMap,searchNodes.peek()); //Pass the top node of SearchNodes back into reachable to be searched. The process is repeated&lt;br /&gt;
				}&lt;br /&gt;
				catch(NullPointerException f) //When we reach the final node we break out of the loop and return our Set of destination nodes&lt;br /&gt;
				{&lt;br /&gt;
					if(searchNodes.size() == 0) //We're done searching&lt;br /&gt;
						break;&lt;br /&gt;
					else&lt;br /&gt;
						reachable(graphMap,searchNodes.peek());&lt;br /&gt;
				}&lt;br /&gt;
				break;&lt;br /&gt;
			}&lt;br /&gt;
			break;&lt;br /&gt;
		}&lt;br /&gt;
		return reachableNodes;&lt;br /&gt;
	}&lt;br /&gt;
	public static void main(String[] args)&lt;br /&gt;
	{&lt;br /&gt;
		Map&amp;lt;String,Set&amp;lt;String&amp;gt;&amp;gt; graphMap = new ArrayMap&amp;lt;String,Set&amp;lt;String&amp;gt;&amp;gt;();&lt;br /&gt;
		TypedBufferReader tbr = new TypedBufferReader(&amp;quot;Enter name of file with graph&amp;quot;);&lt;br /&gt;
		//Repeatedly read lines from a file until the EOFException is thrown.&lt;br /&gt;
		for (;;)&lt;br /&gt;
		{&lt;br /&gt;
			try&lt;br /&gt;
			{&lt;br /&gt;
				String line = tbr.readLine();&lt;br /&gt;
				StringTokenizer st = new StringTokenizer(line, &amp;quot;;&amp;quot;);&lt;br /&gt;
				String sourceNode = st.nextToken();&lt;br /&gt;
&lt;br /&gt;
				while (st.hasMoreTokens())&lt;br /&gt;
				{&lt;br /&gt;
					String token = st.nextToken();&lt;br /&gt;
&lt;br /&gt;
					//Update map for the current node&lt;br /&gt;
					Set&amp;lt;String&amp;gt; nodes = graphMap.get(sourceNode);&lt;br /&gt;
					if (nodes == null)&lt;br /&gt;
					{&lt;br /&gt;
						nodes = new ArraySet&amp;lt;String&amp;gt;();&lt;br /&gt;
						graphMap.put(sourceNode,nodes);&lt;br /&gt;
					}&lt;br /&gt;
					nodes.add(token);&lt;br /&gt;
				}&lt;br /&gt;
			} catch (EOFException e) {break;}&lt;br /&gt;
		}&lt;br /&gt;
		printGraph(graphMap, &amp;quot;Graph: source -&amp;gt; {destination} edges&amp;quot;);&lt;br /&gt;
		String start = Prompt.forString(&amp;quot;\nEnter node to start from&amp;quot;);&lt;br /&gt;
		searchNodes.add(start); //Pass the start node to searchNodes queue&lt;br /&gt;
		System.out.println(&amp;quot;Node reachable from &amp;quot; + start + &amp;quot; = &amp;quot; + reachable(graphMap,start));&lt;br /&gt;
	}&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Derek Elder</name></author>
	</entry>
</feed>