-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Solve p111 in rust #43
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
/* | ||
Project Euler Problem 111 | ||
|
||
*/ | ||
use std::iter::zip; | ||
|
||
use crate::include::primes::primes_until; | ||
use crate::include::utils::Answer; | ||
|
||
pub fn p0111() -> Answer { | ||
let ten_9: u64 = 10_u64.pow(9); | ||
let ten_10: u64 = 10_u64.pow(10); | ||
let mut answer: u64 = 0; | ||
Check warning Code scanning / clippy variable does not need to be mutable Warning
variable does not need to be mutable
Check warning Code scanning / clippy variable does not need to be mutable Warning
variable does not need to be mutable
Check warning Code scanning / clippy unused variable: answer Warning
unused variable: answer
Check warning Code scanning / clippy unused variable: answer Warning
unused variable: answer
|
||
let mut subanswer: Vec<u64> = vec![0; 10]; | ||
let mut current: Vec<usize> = vec![0; 10]; | ||
for p in primes_until::<u64>(ten_10).filter(|x| *x > ten_9) { | ||
let s = p.to_string(); | ||
for digit in 0..=9 { | ||
let idx = digit as usize; | ||
let count = s.bytes().filter(|b| *b == digit + b'0').count(); | ||
if count > current[idx] { | ||
current[idx] = count; | ||
subanswer[idx] = p; | ||
} else if count == current[idx] { | ||
subanswer[idx] += p; | ||
} | ||
Comment on lines
+21
to
+26
Check warning Code scanning / clippy if chain can be rewritten with match Warning
if chain can be rewritten with match
Comment on lines
+21
to
+26
Check warning Code scanning / clippy if chain can be rewritten with match Warning
if chain can be rewritten with match
|
||
} | ||
} | ||
return Answer::Int(subanswer.into_iter().sum::<u64>().into()); | ||
} |
Check warning
Code scanning / clippy
unused import: std::iter::zip Warning