Iterative GCD function to find GCD coefficients
Difference between en1 and en2, changed 325 character(s)
Hi!↵

I was hoping someone could help me understand how this bit of code works written by [saeed_odak](https://mirror.codeforces.com/profile/saeed_odak) in this submission to 1117E : [code](https://mirror.codeforces.com/contest/1117/submission/50126643): ↵

- `int mul_inv(int a, int b) { //Returns multiplicative inverse of a wrt b`↵
- ` int b0 = b, t, q;`↵
- ` int x0 = 0, x1 = 1;`↵
- ` if (b == 1) return 1;`↵
- ` while (a > 1) {`↵
- ` q = a / b;`↵
- ` t = b, b = a % b, a = t;`↵
- ` t = x0, x0 = x1 - q * x0, x1 = t;`↵
- ` }`↵
- ` if (x1 < 0) x1 += b0;`↵
- ` return x1;`↵
- `}`↵
``↵
- I think understanding how to write an iterative GCD function that develops GCD coeffecients would be helpful to understand this piece of code, but I can't seem to come up with a way to do so and online searches only provide code and not good explanations.↵

Any help would be appreciated.↵

Thank you! 


EDIT: Resolved. Looks like there were actually sources that explained that algorithm well that I missed. The wikipedia page [Wikipedia](https://en.wikipedia.org/wiki/Extended_Euclidean_algorithm) itself details the algorithm quite well. Looks like I posted prematurely without doing enough searching on my part.↵

Sorry!

History

 
 
 
 
Revisions
 
 
  Rev. Lang. By When Δ Comment
en2 English gud_day 2019-11-11 16:24:58 325
en1 English gud_day 2019-11-11 15:23:45 931 Initial revision (published)