1. Đề bài nghiệm phương trình x1+x2+x3+…+xn = m
cho trước n và m (n<=10, m<=20) Viết chương xuất ra các nghiệm phương trình x1+x2+x3+…+xn = m. nghiệm của phương trình là 1 số nguyên dương.
Input
– một dòng duy nhất gồm 2 số n, m
Output
– xuất ra tất cả tập nghiệm, mỗi dòng gồm n số, và các tập nghiệm không là hoán vị của nhau
2. Hướng dẫn giải
Áp dụng thuật toán quay lui + đặt cận
3. Code tham khảo
const fi='';
type data=longint;
var
f:text;
m,n:data;
luu:array[0..1000] of data;
procedure xuat;
var i,j:data;
begin
for i:=1 to n do
write(luu[i],' ');
writeln;
end;
procedure try(i:data);//tim dap an cho nghiem thu i
var j,d:data;
begin
d:=m-(n-i);
for j:=d downto 1 do
begin
m:=m-j;
luu[i]:=j;
if (i<n) and (luu[i]<=luu[i-1]) then
try(i+1)
else
if (m=0) and (luu[i]<=luu[i-1]) then
xuat;
m:=m+j;
end;
end;
begin
assign(f,fi); reset(f);
readln(f,n,m);
close(f);
luu[0]:=high(data);
try(1);
readln;
end.