Trang chủ Tin Học Lớp 8 Bài 2: Đội hình thi đấu điền kinh. Giải thi...

Bài 2: Đội hình thi đấu điền kinh. Giải thi đấu điền kinh được tổ chức tại một sân vận động có N đường đua. Mỗi lượt thi đấu có N vận động viên có số áo khác n

Câu hỏi :

Bài 2: Đội hình thi đấu điền kinh. Giải thi đấu điền kinh được tổ chức tại một sân vận động có N đường đua. Mỗi lượt thi đấu có N vận động viên có số áo khác nhau tham gia trên mỗi đường đua khác nhau. Hãy nêu các cách sắp xếp và số lượng các cách sắp xếp các vận động viên tham gia thi đấu trong mỗi lượt đua. Dữ liệu vào là tệp văn bản DIENKINH.INP có cấu trúc: - Dòng đầu tiên ghi số N (2

Lời giải 1 :

var
   a,k:array[0..7] of word;
   duyet:array[0..7] of boolean;
   i,n:byte;
   dem:word;
   f:text;
const fi='DIENKINH.INP';
fo='DIENKINH.OUT';
procedure xuat;
var ii:byte;
begin
    for ii:=1 to n do write(f,k[ii],' ');writeln(f);inc(dem);
end;
procedure hoanvi(i:byte);
var j:byte;
begin
  if i<=n then
    for j:=1 to n do
       begin
           if duyet[j]=true then
              begin
                  k[i]:=a[j];
                  duyet[j]:=false;
                  hoanvi(i+1);
                  duyet[j]:=true;
              end;
       end
  else xuat;
end;
begin
    assign(f,fi);reset(f);
    readln(f,n);
    for i:=1 to n do read(f,a[i]);
    close(f);
    assign(f,fo);rewrite(f);
    fillchar(duyet,sizeof(duyet),true);
    hoanvi(1);
    writeln(f,dem);
    close(f);
end.

Thảo luận

-- Vào nhóm tui ko?
-- ah hỏi e à :D?
-- có chứ a
-- Phải :))
-- :)) nhóm mới tạo thì phải :))
-- Đúng rồi

Lời giải 2 :

uses crt;
var f:text; i,n:longint; a,b:array[1..10000000]of longint;
procedure print;
var i,d,j,kt:longint;
begin
   d:=0;
   for i:=1 to n do 
      begin 
         kt:=0;
         for j:=1 to i-1 do if b[i]=b[j] then kt:=1;
         if kt=0 then inc(d);
      end;
   if d=n then 
      begin
         for i:=1 to n do write(f,a[b[i]],' ');
         writeln(f); 
      end;
end;
function dequy(a:longint):longint;
var i:longint;
begin
   if a=n+1 then print else
         for i:=1 to n Do
            begin
               b[a]:=i;
               dequy(a+1);
            end;
end;
begin
clrscr;
   assign(f,'DIENKINH.INP');reset(f);
      readln(f,n); 
      for i:=1 to n do read(f,a[i]);
   close(f);
   assign(f,'DIENKINH.OUT');rewrite(f);
      dequy(1);
   close(f); 
end.

Bạn có biết?

Tin học, tiếng Anh: informatics, tiếng Pháp: informatique, là một ngành khoa học chuyên nghiên cứu quá trình tự động hóa việc tổ chức, lưu trữ, xử lý và truyền dẫn thông tin của một hệ thống máy tính cụ thể hoặc trừu tượng (ảo). Với cách hiểu hiện nay, tin học bao hàm tất cả các nghiên cứu và kỹ thuật có liên quan đến việc mô phỏng, biến đổi và tái tạo thông tin.

Nguồn : Wikipedia - Bách khoa toàn thư

Tâm sự 8

Lớp 8 - Năm thứ ba ở cấp trung học cơ sở, học tập bắt đầu nặng dần, sang năm lại là năm cuối cấp áp lực lớn dần nhưng các em vẫn phải chú ý sức khỏe nhé!

Nguồn : ADMIN :))

Liên hệ hợp tác hoặc quảng cáo: gmail

Điều khoản dịch vụ

Copyright © 2021 HOCTAPSGK