"Why re-invent the wheel?", you ask?
How about: "I like the challenge and see it as brain-sport".
I absolutely *hate* hand-wavey claims like "just download it from the 'net" - that doesn't solve anyone's problems at all! I don't want to be spoon fed, I wouldn't be here if I did
By the way, even though I have identified the problem, I haven't actually found a tool/library that I thought would actually solve this problem. Maybe I'm blind or keep looking in the wrong place.
(or could it be that I'm "restricting" my search to non-windows platforms?)
As far as I can tell, I've got the theory "not entirely wrong", but something is still missing - at least I'm up to level 200+ now - but it's nothing like runaway robot where once I came up with *my solution*, I coded it and watched it blast through all 500 levels. That was a real buzz!

Just running some code I got from somewhere else? Boring!
Anyway, since my last post I've built an interactive one-of-us-graph-viewer/solver so that I can stop the algorithm, step back and forwards and even change decisions, and actually *see* what's going on. (written in java btw.)
Speed is not the problem, it can be used interactively and isn't even multi-threaded.
But it HAS taught me all kinds of stuff and it also shows how the puzzles get more intricate (e.g. I can actually see and identity different structures in the graphs - at least visually, the challenge is to identify them programmatically).
The viewer still has a few bugs but if someone is interested, I could post it on github and you could try out your own algorithms. (I still need to clean it up a bit first before I publish it though).
If/when I publish it, it *won't* have the solver class - just the ability to visualise the levels and an API so you can add your own solver to it. (the solver is a delegate - the program works fine without a solver, just can't do anything automatically)
As for perl, I've written code for one-of-us in perl, java, go & C - the language really isn't my problem

(this should be solvable in any language - the question is not how good the language is, but whether you've simplified the problem and whether you're using the language effectively)
Cheers