#!/usr/bin/ruby
func mul_inv(a, b) {
b == 1 && return 1;
var (b0, x0, x1) = (0, 0, 1);
while (a > 1) {
(a, b, x0, x1) = (b, a % b, x1 - x0*int(a / b), x0);
};
x1 < 0 ? x1+b0 : x1;
}
func chinese_remainder(*n) {
var N = n«*»;
func (*a) {
n.range.map { |i|
var p = int(N / n[i]);
a[i] * mul_inv(p, n[i]) * p;
}.sum
}
}
say chinese_remainder(3, 5, 7)(2, 3, 2);