fn main() { let v = read_vec::(); let (n, k) = (v[0] as usize, v[1]); let mut a = read_vec::(); a.sort(); a.reverse(); let mut ans = 0; for state in 0..1 << (n - 1) { let mut temp = k; for j in 0..n - 1 { if (state >> j) & 1 == 1 { temp %= a[j]; } } temp %= a[n - 1]; ans = std::cmp::max(ans, temp); } println!("{}", ans); } fn read() -> T { let mut s = String::new(); std::io::stdin().read_line(&mut s).ok(); s.trim().parse().ok().unwrap() } fn read_vec() -> Vec { read::() .split_whitespace() .map(|e| e.parse().ok().unwrap()) .collect() }