不定方程求解
题目描述
给定正整数 a a a, b b b, c c c。求不定方程 a x + b y = c ax+by=c ax+by=c 关于未知数 x x x 和 y y y 的所有非负整数解组数。
输入格式
一行,包含三个正整数 a a a, b b b, c c c,两个整数之间用单个空格隔开。每个数均不大于 1000 1000 1000。
输出格式
一个整数,即不定方程的非负整数解组数。
样例 #1
样例输入 #1
2 3 18
样例输出 #1
4
code:
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int a,b,c,y,ans;
cin>>a>>b>>c;
//x最大取值是c/a;从0开始枚举 ,
for(int x=0;x<=c/a;x++)
{
//得到y的计算表达式
y=(c-a*x)/b;
//判断式子是否合理,合理计数加1
if(a*x+b*y==c)
ans++;
}
cout<<ans<<endl;
return 0;
}
result: