After reviewing the available paths, you realize you might have time to visit a single small cave twice. Specifically, big caves can be visited any number of times, a single small cave can be visited at most twice, and the remaining small caves can be visited at most once. However, the caves named start
and end
can only be visited exactly once each: once you leave the start
cave, you may not return to it, and once you reach the end
cave, the path must end immediately.
Now, the 36
possible paths through the first example above are:
start,A,b,A,b,A,c,A,end
start,A,b,A,b,A,end
start,A,b,A,b,end
start,A,b,A,c,A,b,A,end
start,A,b,A,c,A,b,end
start,A,b,A,c,A,c,A,end
start,A,b,A,c,A,end
start,A,b,A,end
start,A,b,d,b,A,c,A,end
start,A,b,d,b,A,end
start,A,b,d,b,end
start,A,b,end
start,A,c,A,b,A,b,A,end
start,A,c,A,b,A,b,end
start,A,c,A,b,A,c,A,end
start,A,c,A,b,A,end
start,A,c,A,b,d,b,A,end
start,A,c,A,b,d,b,end
start,A,c,A,b,end
start,A,c,A,c,A,b,A,end
start,A,c,A,c,A,b,end
start,A,c,A,c,A,end
start,A,c,A,end
start,A,end
start,b,A,b,A,c,A,end
start,b,A,b,A,end
start,b,A,b,end
start,b,A,c,A,b,A,end
start,b,A,c,A,b,end
start,b,A,c,A,c,A,end
start,b,A,c,A,end
start,b,A,end
start,b,d,b,A,c,A,end
start,b,d,b,A,end
start,b,d,b,end
start,b,end
The slightly larger example above now has 103
paths through it, and the even larger example now has 3509
paths through it.
Given these new rules, how many paths through this cave system are there? Determine this in the following way:
Write a function paths
that takes the pathname (String
) of a text file containing a rough map of a cave system. The function must return the number of paths (int
) through this cave system.
The function must be declared statically in the class Submission.
In this interactive session we assume the text files caves01.txt
1, caves02.txt
2 and caves03.txt
3 to be located in the current directory.
> Submission.paths("caves01.txt")
36
> Submission.paths("caves02.txt")
103
> Submission.paths("caves03.txt")
3509