Răspuns :
Sa iti fie de folos. L-am facut in C++. Am folosit o forma mai nelineara. As recomanda cand ai timp sa incerci sa il faci cu backtraking.
#include <iostream>
using namespace std;
void Afisare(long* a,int n)
{
cout<< "DEBUG: ";
int i=0;
while(i<n && a[i]!=0)
{
cout<<a[i]<<" "<<endl;
i++;
}
cout<<endl;
}
int main()
{
int n;
cin>>n;
long *a;
bool gasit = false;
cout<<"DEBUG: n="<<n<<endl;
for(long i = 1;i<=2*n;i++)
{
long s = 0;
a = new long[2*n];
int index = 0;
for(long j=i;i<=n*n/2 && s < n*n;j++)
{
s+=j;
a[index] = j;
index++;
}
if(s==n*n)
{
gasit = true;
break;
}
}
if(gasit)
Afisare(a,2*n);
else
cout<<"DEBUG: NU ESTE NOROCOS!";
cout<<endl<<"DEBUG: Gata!";
return 0;
}
Vă mulțumim pentru vizita pe site-ul nostru dedicat Informatică. Sperăm că informațiile oferite v-au fost de ajutor. Nu ezitați să ne contactați pentru orice întrebare sau dacă aveți nevoie de asistență suplimentară. Vă așteptăm cu drag data viitoare și nu uitați să ne adăugați la favorite!