Сумма минимальных значений x и y, удовлетворяющих уравнению ax + by = c
Для трех целых чисел a , b и c, представляющих линейное уравнение вида ax + by = c , задача состоит в том, чтобы найти решение (x, y) данного уравнения, такое, что (x + y) минимизируется. Если для приведенного выше уравнения не существует решения, выведите «-1» .
 Примечание: x и y - неотрицательные целые числа.
Примеры:
Input: a = 2, b = 2, c = 0
Output: 0
Explanation:
The given equation is 2x + 2y = 0.
Therefore, x = 0 and y = 0 is the required solution with minimum value of (x + y).Input: a = 2, b = 2, c = 1
Output: -1
Explanation:
The given equation is 2x + 2y = 1.
No solution exists for the given equation for positive values of x and y.
Подход: Чтобы решить указанную выше проблему, найдите любое решение, скажем (x, y) данного линейного диофантова уравнения, а затем, соответственно, найдите значение x и минимизируйте сумму.
 Ниже приведено решение (x ', y') данного уравнения:
[Tex]y’ = y – k * frac{a}{g} [/Tex]
where g is gcd(a, b) and k is any integer.
[Tex]x’ + y’ = x + y + k*frac{b-a}{g} [/Tex]
Из приведенного выше уравнения мы видим, что:
- Если a меньше b, нам нужно выбрать наименьшее возможное значение K.
- Иначе, если a больше b, нам нужно выбрать максимально возможное значение K.
- Если a = b, все решения будут иметь одинаковую сумму (x + y) .
Ниже представлена реализация описанного выше подхода:
C ++
| // C++ program for the above approach#include <bits/stdc++.h>usingnamespacestd;// Function to find the gcd of a & b// by Euclid's method// x and y store solution of// equation ax + by = gintgcd(inta,intb,int* x,int* y){    if(b == 0) {        *x = 1;        *y = 0;        returna;    }    intx1, y1;    intstore_gcd = gcd(b, a % b,                        &x1, &y1);    // Euclidean Algorithm    *x = y1;    *y = x1 - y1 * (a / b);    // store_gcd returns    // the gcd of a and b    returnstore_gcd;}// Function to find any// possible solutionintpossible_solution(inta,intb,                    intc,int* x0,                    int* y0,int* g){    *g = gcd(fabs(a),fabs(b), x0, y0);    // Condition if solution    // does not exists    if(c % *g) {        return0;    }    *x0 *= c / *g;    *y0 *= c / *g;    // Adjusting the sign    // of x0 and y0    if(a < 0)        *x0 *= -1;    if(b < 0)        *y0 *= -1;    return1;}// Function to shift solutionvoidshift_solution(int* x,int* y,                    inta,intb,                    intshift_var){    // Shifting to obtain    // another solution    *x += shift_var * b;    *y -= shift_var * a;}// Function to find minimum// value of x and yintfind_min_sum(inta,intb,intc){    intx, y, g;    // g is the gcd of a and b    if(!possible_solution(a, b, c,                        &x, &y, &g))        return-1;    a /= g;    b /= g;    // Store sign of a and b    intsign_a = a > 0 ? +1 : -1;    intsign_b = b > 0 ? +1 : -1;    shift_solution(&x, &y, a, b, -x / b);    // If x is less than 0, then    // shift solution    if(x < 0)        shift_solution(&x, &y, a, b, sign_b);    intminx1 = x;    shift_solution(&x, &y, a, b, y / a);    // If y is less than 0, then    // shift solution    if(y < 0)        shift_solution(&x, &y, a, b, -sign_a);    intminx2 = x;    if(minx2 > x)        swap(minx2, x);    intminx = max(minx1, minx2);    // Find intersection such    // that both x and y are positive    if(minx > x)        return-1;    // miny is value of y    // corresponding to minx    intminy = (c - a * x) / b;    // Returns minimum value of x+y    return(miny + minx);}// Driver Codeintmain(){    // Given a, b, and c    inta = 2, b = 2, c = 0;    // Function Call    cout << find_min_sum(a, b, c)        <<"
";    return0;} | 
Джава
| // Java program for the above approachimportjava.lang.*;classGFG{    publicstaticintx =0, y =0,                 x1 =0, y1 =0;publicstaticintx0 =0, y0 =0,                   g =0;// Function to find the gcd of a & b// by Euclid's method// x and y store solution of// equation ax + by = gpublicstaticintgcd(inta,intb){    if(b ==0)    {        x =1;        y =0;        returna;    }    intstore_gcd = gcd(b, a % b);    // Euclidean Algorithm    x = y1;    y = x1 - y1 * (a / b);    // store_gcd returns    // the gcd of a and b    returnstore_gcd;}// Function to find any// possible solutionpublicstaticintpossible_solution(inta,intb,                                    intc){    g = gcd(Math.abs(a), Math.abs(b));    // Condition if solution    // does not exists    if(c % g !=0)    {        return0;    }    x0 *= c / g;    y0 *= c / g;    // Adjusting the sign    // of x0 and y0    if(a <0)        x0 *= -1;    if(b <0)        y0 *= -1;    return1;}// Function to shift solutionpublicstaticvoidshift_solution(inta,intb,                                  intshift_var){        // Shifting to obtain    // another solution    x += shift_var * b;    y -= shift_var * a;}// Function to find minimum// value of x and ypublicstaticintfind_min_sum(inta,intb,                               intc){    intx =0, y =0, g =0;    // g is the gcd of a and b    if(possible_solution(a, b, c) ==0)        return-1;    if(g !=0)    {        a /= g;        b /= g;    }    // Store sign of a and b    intsign_a = a >0? +1: -1;    intsign_b = b >0? +1: -1;    shift_solution(a, b, -x / b);    // If x is less than 0, then    // shift solution    if(x <0)        shift_solution(a, b, sign_b);    intminx1 = x;    shift_solution(a, b, y / a);    // If y is less than 0, then    // shift solution    if(y <0)        shift_solution(a, b, -sign_a);    intminx2 = x;    if(minx2 > x)    {        inttemp = minx2;        minx2 = x;        x = temp;    }    intminx = Math.max(minx1, minx2);    // Find intersection such    // that both x and y are positive    if(minx > x)        return-1;    // miny is value of y    // corresponding to minx    intminy = (c - a * x) / b;    // Returns minimum value of x+y    return(miny + minx);}// Driver Codepublicstaticvoidmain(String[] args){        // Given a, b, and c    inta =2, b =2, c =0;    // Function call    System.out.println(find_min_sum(a, b, c));}}// This code is contributed by grand_master | 
Python3
| # Python3 program for the# above approachx, y, x1, y1=0,0,0,0x0, y0, g=0,0,0# Function to find the gcd# of a & b by Euclid's method# x and y store solution of# equation ax + by = gdefgcd(a, b) :        globalx, y, x1, y1    if(b==0) :            x=1        y=0        returna        store_gcd=gcd(b, a%b)        # Euclidean Algorithm    x=y1    y=x1-y1*(a//b)        # store_gcd returns    # the gcd of a and b    returnstore_gcd# Function to find any# possible solutiondefpossible_solution(a, b, c) :        globalx0, y0, g    g=gcd(abs(a),abs(b))        # Condition if solution    # does not exists    if(c%g !=0) :            return0        x0*=c//g    y0*=c//g        # Adjusting the sign    # of x0 and y0    if(a <0) :        x0*=-1    if(b <0) :        y0*=-1    return1# Function to shift solutiondefshift_solution(a, b, shift_var) :        globalx, y    # Shifting to obtain    # another solution    x+=shift_var*b    y-=shift_var*a# Function to find minimum# value of x and ydeffind_min_sum(a, b, c) :    globalx, y, g    x, y, g=0,0,0        # g is the gcd of a and b    if(possible_solution(a, b, c)==0) :        return-1        if(g !=0) :            a//=g        b//=g        # Store sign of a and b    ifa >0:        sign_a=1    else:        sign_a=-1        ifb >0:        sign_b=1    else:        sign_b=-1        shift_solution(a, b,-x//b)        # If x is less than 0,    # then shift solution    if(x <0) :        shift_solution(a, b, sign_b)        minx1=x        shift_solution(a, b, y//a)        # If y is less than 0,    # then shift solution    if(y <0) :        shift_solution(a, b,-sign_a)        minx2=x        if(minx2 > x) :            temp=minx2        minx2=x        x=temp        minx=max(minx1, minx2)        # Find intersection such    # that both x and y are positive    if(minx > x) :        return-1        # miny is value of y    # corresponding to minx    miny=(c-a*x)//b        # Returns minimum value    # of x + y    return(miny+minx)# Given a, b, and ca, b, c=2,2,0# Function callprint(find_min_sum(a, b, c))# This code is contributed by divyesh072019 | 
C #
| // C# program for the// above approachusingSystem;classGFG{publicstaticintx = 0, y = 0,                  x1 = 0, y1 = 0;publicstaticintx0 = 0, y0 = 0,                  g = 0;// Function to find the gcd// of a & b by Euclid's method// x and y store solution of// equation ax + by = gpublicstaticintgcd(inta,intb){  if(b == 0)  {    x = 1;    y = 0;    returna;  }  intstore_gcd = gcd(b,                      a % b);  // Euclidean Algorithm  x = y1;  y = x1 - y1 *      (a / b);  // store_gcd returns  // the gcd of a and b  returnstore_gcd;}// Function to find any// possible solutionpublicstaticintpossible_solution(inta,                                    intb,                                    intc){  g = gcd(Math.Abs(a),          
                            
                         |