Trang chủ Tin Học Lớp 9 Câu đơn giản thôi Pascal Viết chương trình với cái...

Câu đơn giản thôi Pascal Viết chương trình với cái thuật toán dùm với :>>>>Bài 3: Dãy có giá trị lớn nhất. (7 điểm) Cho một xâu S có chiều dài N (1

Câu hỏi :

Câu đơn giản thôi Pascal Viết chương trình với cái thuật toán dùm với :>>>>

image

Lời giải 1 :

Chương trình:

uses crt;
var f:text; i,j,n,x,k,m:longint; s,kq:string;
begin
clrscr;
   assign(f,'input.pas');reset(f);
      readln(f,s);
      readln(f,k);
   close(f);
   assign(f,'output.pas');rewrite(f);
   m:=1;
      for i:=1 to k do
         begin
            x:=1;
            for j:=m to length(s)-(k-i) do
               if (s[j]>s[x]) then x:=j;
            kq:=kq+s[x]; delete(s,x,1); m:=x;
         end;
      writeln(f,kq);
   close(f);
readln
end.

Thuật toán:

Ta sẽ tìm 3 số lớn nhất theo thứ tự là:

    Chạy từ 1 đến k (tìm k số):

        Chạy j từ m đến length(s)-(k-i) (m là biến đánh dấu vd như là mình chọn số 9 rồi thì không                                                                  được chọn số khác đứng trước nó. length(s)-(k-i) là giới hạn để                                                            chọn được số 6): tìm max

         xóa max, thêm vào kết quả.

Mong được góp ý

Cho mình xin hay nhất.

Thảo luận

-- Chuẩn rồi đó men :vvv
-- Cảm ơn bạn

Lời giải 2 :

uses crt;

var f,g:text;

      s:string[100];

      n:byte;

procedure kt_ndl;

     begin

          Assign(f,'DAYCON.INP');     

          Assign(g,'DAYCON.OUT');     rewrite(g);

          {$I-} reset(f); {$I+}

          if IOresult<>0 then

               begin

                    rewrite(f);

                    reset(f);

               end;

          readln(f,s);

          readln(f,n);

          close(f);

     end;

procedure xuly;

var st:string[100];

       i,vt:byte;

       max:char;

begin

     st:='';  vt:=1;

     while length(st)<>n do

          begin

               max:=s[vt];

               for i:=vt+1 to length(s)-n+length(st)+1 do

                    if s[i]>max then

                         begin

                              max:=s[i];

                              vt:=i;

                         end;

               st:=st+max;

               vt:=vt+1;

          end;

     write(g,st);

     close(g);

end;

BEGIN

kt_ndl; xuly;

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ự 9

Lớp 9 - Là năm cuối ở cấp trung học cơ sở, sắp phải bước vào một kì thi căng thẳng và sắp chia tay bạn bè, thầy cô và cả kì vọng của phụ huynh ngày càng lớn mang tên "Lên cấp 3". Thật là áp lực nhưng các em hãy cứ tự tin vào bản thân là sẻ vượt qua nhé!

Nguồn : ADMIN :))

Copyright © 2021 HOCTAP247