pub fn extended_euclidean_algorithm(a:i64,b:i64)->(i64, i64, i64){ if a <= 0 || b <= 0{
        panic!("natural numbers only")
    }
    let mut q =0;
    let mut r1 = a;
    let mut r2=b;
    let mut s = 1;
    let mut t = 0;
    let mut s1 = 0;
    let mut t1 = 1;
    loop{
        q = r1/r2;
        let new_r = r2;
        let new_s = s1;
        let new_t = t1;
        r2 = r1 % r2;
        s1 = s - q * s1;
        s = new_s;
        t1 = t - q * t1;
        t = new_t;
        r1 =  new_r;
        if r2 == 0{
        break  (s*a + t*b, s, t);
        }
   
    }
    
}
#[cfg(test)]
mod tests {
    use super::*;
    #[test]
    fn moon_math1() {
        let (gcd, s, t)=extended_euclidean_algorithm(27, 5);
        assert_eq!(gcd,1);
        assert_eq!(s, -2);
        assert_eq!(t, 11);
    }
    #[test]
    fn moon_math2() {
      let (gcd, s, t)=extended_euclidean_algorithm(45, 10);
        assert_eq!(gcd,5);
        assert_eq!(s, 1);
        assert_eq!(t, -4);
    }
    #[test]
    fn moon_math3() {
      let (gcd, s, t) =extended_euclidean_algorithm(13, 11);
        assert_eq!(gcd,1);
        assert_eq!(s, -5);
        assert_eq!(t, 6);
    }
    #[test]
    fn moon_math4() {
      let (gcd, s, t)=extended_euclidean_algorithm(13, 12);
        assert_eq!(gcd,1);
        assert_eq!(s, 1);
        assert_eq!(t, -1);
    }
      #[test]
    #[should_panic(expected = "natural numbers only")]
    fn moon_math5() {
    extended_euclidean_algorithm(0, 12);
    }
      #[test]
    #[should_panic(expected = "natural numbers only")]
    fn moon_math6() {
    extended_euclidean_algorithm(12, 0);
    }
       #[test]
    #[should_panic(expected = "natural numbers only")]
    fn moon_math7() {
    extended_euclidean_algorithm(0, 0);
    }
   
}