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.
185 lines
4.0 KiB
185 lines
4.0 KiB
12 months ago
|
use std::collections::HashSet;
|
||
|
|
||
|
fn er() -> Vec<u32> {
|
||
|
let mut nums = Vec::new();
|
||
|
let size = 1000000;
|
||
|
for n in 0..size+1 { nums.push(true); }
|
||
|
let mut p = 1;
|
||
|
loop {
|
||
|
let mut found = false;
|
||
|
for i in p+1..size {
|
||
|
if nums[i] {
|
||
|
found = true;
|
||
|
p = i;
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
if !found { break; }
|
||
|
for i in (2 * p .. size).step_by(p) {
|
||
|
nums[i] = false;
|
||
|
}
|
||
|
}
|
||
|
let mut res = Vec::new();
|
||
|
for i in 2..size {
|
||
|
if nums[i] { res.push(i as u32); }
|
||
|
}
|
||
|
return res;
|
||
|
}
|
||
|
|
||
|
fn rt(n: u32) -> u32 {
|
||
|
let s = n.to_string();
|
||
|
let mut chars = s.chars();
|
||
|
let f = chars.next().unwrap();
|
||
|
//chars.next_back();
|
||
|
let mut res = String::from(chars.as_str());
|
||
|
res.push(f);
|
||
|
res.parse::<u32>().unwrap()
|
||
|
}
|
||
|
|
||
|
fn rp(n: u32, is: u32, k: u8) -> u32 {
|
||
|
let s = n.to_string();
|
||
|
let mut hs = HashSet::new();
|
||
|
let mut iss = is;
|
||
|
while iss > 0 {
|
||
|
hs.insert(iss%10);
|
||
|
iss/=10;
|
||
|
}
|
||
|
|
||
|
let mut ress = 0;
|
||
|
let mut index = 0;
|
||
|
for c in s.chars() {
|
||
|
ress*=10;
|
||
|
if !hs.contains(&(index+1)) {
|
||
|
let cc = c.to_string().parse::<u32>().unwrap();
|
||
|
//println!("--{} {} {} {}", cc, c, index+1, s);
|
||
|
ress += cc;
|
||
|
} else {
|
||
|
ress += k as u32;
|
||
|
}
|
||
|
index+=1;
|
||
|
}
|
||
|
return ress;
|
||
|
}
|
||
|
|
||
|
fn replacements(n: u32, is:u32, ps: &HashSet<u32>) -> usize {
|
||
|
//let mut res = Vec::new();
|
||
|
//println!("-------");
|
||
|
let mut res = 0;
|
||
|
let mut found = false;
|
||
|
for i in 0..=9 {
|
||
|
let r=rp(n, is, i);
|
||
|
if r.to_string().len() < n.to_string().len() { continue; }
|
||
|
if r == n { found = true; }
|
||
|
//println!("{} {} {} {}", r, n, is, i);
|
||
|
if ps.contains(&r) {
|
||
|
//println!(":: {} {} {} {}", r, n,is,i);
|
||
|
//res.push(r);
|
||
|
res+=1;
|
||
|
}
|
||
|
}
|
||
|
if !found { return 0; }
|
||
|
return res;
|
||
|
}
|
||
|
|
||
|
fn rm(n: u32, _: &Vec<u32>, ps: &HashSet<u32>) -> usize {
|
||
|
let len = n.to_string().len();
|
||
|
let rms = lpp(len as u8);
|
||
|
let mut max_rpls = 0;
|
||
|
//println!("len {}", rms.len());
|
||
|
for r in rms.iter() {
|
||
|
if r.to_string().len() > len {
|
||
|
break;
|
||
|
}
|
||
|
//if !is_diff_tn(*r, len as u32) {
|
||
|
// continue;
|
||
|
//}
|
||
|
let rpsss = replacements(n, *r, ps);
|
||
|
//println!("{} {} {}", rpsss, n, *r);
|
||
|
if rpsss > max_rpls {
|
||
|
max_rpls = rpsss;
|
||
|
//println!("-------- {}", *r);
|
||
|
//for r in rpsss.iter() {
|
||
|
// println!("{}", r);
|
||
|
//}
|
||
|
}
|
||
|
}
|
||
|
return max_rpls;
|
||
|
}
|
||
|
|
||
|
fn b_t_is(n: u32) -> u32 {
|
||
|
let mut rr = n;
|
||
|
let mut index = 1;
|
||
|
let mut res = 0;
|
||
|
while rr > 0 {
|
||
|
let c = rr % 2;
|
||
|
if c == 1 {
|
||
|
res*=10;
|
||
|
res+=index;
|
||
|
}
|
||
|
index+=1;
|
||
|
rr/=2;
|
||
|
}
|
||
|
return res;
|
||
|
}
|
||
|
|
||
|
fn lpp(n: u8) -> Vec<u32> {
|
||
|
let mut res = Vec::new();
|
||
|
let bt = 0;
|
||
|
let mut tn = 1;
|
||
|
for _ in 0..n {
|
||
|
tn *= 2;
|
||
|
}
|
||
|
for i in 1..tn {
|
||
|
res.push(b_t_is(i));
|
||
|
}
|
||
|
|
||
|
return res;
|
||
|
}
|
||
|
|
||
|
|
||
|
fn main() {
|
||
|
//let r = b_t_is(5);
|
||
|
//println!("{}", r);
|
||
|
//return;
|
||
|
//let pmsss = lpp(4);
|
||
|
//for p in pmsss.iter() {
|
||
|
// println!("{}", p);
|
||
|
//}
|
||
|
//return;
|
||
|
let ps = er();
|
||
|
let mut hs = HashSet::new();
|
||
|
for p in ps.iter() {
|
||
|
hs.insert(*p);
|
||
|
}
|
||
|
//let r = rp(56003, 13, 1);
|
||
|
//let id = is_diff(763);
|
||
|
//println!("...");
|
||
|
let rms = lpp(6);
|
||
|
//for r in rs.iter() {
|
||
|
// println!("{}", r);
|
||
|
//}
|
||
|
//
|
||
|
//println!(".x.");
|
||
|
//let v8res = rm(120383, &rms, &hs); // 100109,
|
||
|
//for p in v8res.iter() {
|
||
|
// println!("{}", v8res);
|
||
|
//}
|
||
|
//return;
|
||
|
|
||
|
for p in ps.iter() {
|
||
|
let l = rm(*p, &rms, &hs);
|
||
|
//println!("{}", p);
|
||
|
if l == 8 {
|
||
|
//if *p == 56003 {
|
||
|
println!("{}", p);
|
||
|
//}
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
//println!("{}", bs);
|
||
|
//for r in rsss {
|
||
|
// println!("{}", r);
|
||
|
//}
|
||
|
}
|
||
|
|