Trang chủ Tin Học Lớp 10 Nhập vào một mảng A gồm N phần tử,sắp xếp...

Nhập vào một mảng A gồm N phần tử,sắp xếp dãy theo thứ tự tăng dần và giảm dần (không dòng hai vòng lặp for i,for j để tìm) - câu hỏi 2199233

Câu hỏi :

Nhập vào một mảng A gồm N phần tử,sắp xếp dãy theo thứ tự tăng dần và giảm dần (không dòng hai vòng lặp for i,for j để tìm)

Lời giải 1 :

*Tăng dần:

uses crt;
var i,n:longint;
    a:array[0..1000000] of longint;
procedure sort(l,r:longint);
var i,j,x,temp:longint;
begin
    i:=l;j:=r;x:=a[(l+r) div 2];
    repeat
        while a[i] < x do inc(i);
        while x < a[j] do dec(j);
        if i<=j then
           begin
              temp:=a[i];
              a[i]:=a[j];
              a[j]:=temp;
              inc(i);dec(j);
           end;
    until i>j;
    if l < j then sort(l,j);
    if i < r then sort(i,r);
end;
begin
    clrscr;
    readln(n);
    for i:=1 to n do read(a[i]);
    sort(1,n);
    for i:=1 to n do write(a[i],' ');
readln;readln;
end.

============================

*Giảm dần:

uses crt;
var i,n:longint;
    a:array[0..1000000] of longint;
procedure sort(l,r:longint);
var i,j,x,temp:longint;
begin
    i:=l;j:=r;x:=a[(l+r) div 2];
    repeat
        while a[i] > x do inc(i);
        while x > a[j] do dec(j);
        if i<=j then
           begin
              temp:=a[i];
              a[i]:=a[j];
              a[j]:=temp;
              inc(i);dec(j);
           end;
    until i>j;
    if l < j then sort(l,j);
    if i < r then sort(i,r);
end;
begin
    clrscr;
    readln(n);
    for i:=1 to n do read(a[i]);
    sort(1,n);
    for i:=1 to n do write(a[i],' ');
readln;readln;
end.

Thảo luận

-- Cảm ơn bạn:))

Lời giải 2 :

uses crt;
type tlist = array[1..100000] of longint;
var i,n:longint; a:tlist;
procedure qsort(var a : tlist);

    procedure sort(l,r: longint);
      var
         i,j,x,y: longint;
      begin
         i:=l;
         j:=r;
         x:=a[(l+r) div 2];
         repeat
           while a[i]<x do
            inc(i);
           while x<a[j] do
            dec(j);
           if not(i>j) then
             begin
                y:=a[i];
                a[i]:=a[j];
                a[j]:=y;
                inc(i);
                j:=j-1;
             end;
         until i>j;
         if l<j then
           sort(l,j);
         if i<r then
           sort(i,r);
      end;

    begin
       sort(1,n);
    end;
begin
clrscr;
   write('Nhap n: ');readln(n);
   for i:=1 to n do 
      begin
         write('a[',i,']=');readln(a[i]); 
      end;
   qsort(a);
   for i:=1 to n do write(a[i],' ');
readln
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ự 10

Lớp 10 - Năm thứ nhất ở cấp trung học phổ thông, năm đầu tiên nên có nhiều bạn bè mới đến từ những nơi xa hơn vì ngôi trường mới lại mỗi lúc lại xa nhà mình hơn. Được biết bên ngoài kia là một thế giới mới to và nhiều điều thú vị, một trang mới đang chò đợi chúng ta.

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