Jump to content

Combinações de números cuja soma é um valor dado


anrita

Recommended Posts

tentei fazer assim

#include <stdio.h>

int main()
{
    int n, a, b, c;
    printf("introduza valor:");
    scanf("%d", &n);

    a=n-1;
    b=0;
    c=0;
    if(a<=2)
        printf("nao tem soma");
     else
        while(a>b)
         {
              a=a-1;
              b=b+1;
              c=n-(a+b);
                printf("\n%d+%d+%d", a, b, c);
         }
}
Link to comment
Share on other sites

já é um começo, no entanto, a analisar o código, o que vejo é isto:

while (a < b) {
   a--; // decrementar o 'a'
   b++: // incrementar o 'b'
}

o que indica que o valor de B está directamente relacionado com 'A', o que não é verdade como por exemplo do valor de 9 para N.

9 = 5+3+1
9 = 5+2+2
9 = 4+4+1
9 = 4+3+2
9 = 3+3+3

como podes ver, para o mesmo A, existem mais do que um B em vários casos.

o que necessitas é de mais ciclos

Edited by HappyHippyHippo
example corrected
  • Vote 1
IRC : sim, é algo que ainda existe >> #p@p
Link to comment
Share on other sites

35 minutos atrás, anrita disse:

Mas não dá...

geralmente quem começa a programar, consegue na mesma resolver o problema a força bruta (brute-force),
nomeadamente variando A, B e C nos diversos valores possíveis e comparando sempre se (A+B+C=N) antes de imprimir/output.
tente resolver desta forma e depois tente optimizar o código.
 

Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.