You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
use std::collections::HashSet;
|
|
|
|
use failure::Error;
|
|
|
|
|
|
|
|
#[allow(dead_code)]
|
|
|
|
pub fn solve(input: &str) -> Result<String, Error> {
|
|
|
|
Ok(input
|
|
|
|
.trim()
|
|
|
|
.lines()
|
|
|
|
.map(|line| Passphrase { words: line.into() })
|
|
|
|
.filter(Passphrase::is_valid)
|
|
|
|
.count()
|
|
|
|
.to_string())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[allow(dead_code)]
|
|
|
|
struct Passphrase {
|
|
|
|
words: String,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Passphrase {
|
|
|
|
#[allow(dead_code)]
|
|
|
|
fn is_valid(&self) -> bool {
|
|
|
|
let mut words = HashSet::new();
|
|
|
|
!self.words
|
|
|
|
.split_whitespace()
|
|
|
|
.map(|word| {
|
|
|
|
let mut chars: Vec<String> = word.chars().map(|x| x.to_string()).collect();
|
|
|
|
chars.sort();
|
|
|
|
chars.as_slice().join("")
|
|
|
|
})
|
|
|
|
.any(|word| {
|
|
|
|
if words.contains(&word) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
words.insert(word);
|
|
|
|
false
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|