@samzhang
2017-04-18T18:59:41.000000Z
字数 786
阅读 18766
数论
//下面假设都是非负整数
我们想求得一组使得
根据
如果我们现在有使得
那么我们可以钦定
注意到
所以
注:我们注意到这个方程里面有个未知数却只有个方程,那么根据线性代数相关知识我们可以知道这东西是有无数组解的。
注意到这个等式每一项只与a或b有关,所以我们只需要按照a和b分类一下这个东西就可以获得一组特解
魔改开始!
魔改结束!
看这个东西长得这么漂亮,这么对称,显然我们可以得到一组特解
聪明的你一定发现了这个东西是个递归的式子,那么我们肯定要找到那组base case(也就是递归基). 聪明的你也一定发现了这里的递归基就是当时
当时我们想求使得的话,显然就可以啦,大功告成。
附一下代码:
pair<int,int> exgcd(int a,int b){
if(b == 0)return make_pair(1,0);
pair<int,int>temp = exgcd(b,a%b);
pair<int,int>ans = make_pair(temp.second,temp.first-a/b*temp.second);
return ans;
}