Trang chủ Tin Học Lớp 8 tìm số nguyên dương nhỏ nhất không có trong mảng...

tìm số nguyên dương nhỏ nhất không có trong mảng pascal vd:nhập:n=3 a=2 1 5 in ra: 3 giải thích:1 2 5 có xuất hiện 3 và 4 không xuất hiện mà 3<4 nên in ra 3 nh

Câu hỏi :

tìm số nguyên dương nhỏ nhất không có trong mảng pascal vd:nhập:n=3 a=2 1 5 in ra: 3 giải thích:1 2 5 có xuất hiện 3 và 4 không xuất hiện mà 3

Lời giải 1 :

uses crt;
var i,n,max,a:longint;
 duyet:array[0..10000000] of boolean;
begin
   clrscr;
   write('n=');readln(n); { Nhap n }
   write('a=');
   for i:=1 to n do
     begin
        read(a); { Nhap mang }
        if max<a then max:=a; { Tim gia tri lon nhat trong mang }
        if a>0 then
           duyet[a]:=true;{ Danh dau nhung so nguyen duong da nhap }
     end;
   max:=max+1; { Vi so nho nhat se nam trong khoang 1->max+1 nen +1->max }
   {Kiem tra xem so nao chua xuat hien trong mang }
   for i:=1 to max do
   if duyet[i]=false then
      begin
          write(i);  { In i }
          break;  { Thoat vong lap }
      end;
readln;readln;
end.

Thảo luận

-- tại mình cũng không gọi là mảng nên dùng biến thôi mà đủ :v
-- *gọi lại mảng
-- giải thích đi rồi mk vote 5 sao
-- ukm
-- sao mk chạy ko ra đáp án nơi
-- không biết bạn chạy sao chứ mình vẫn chạy bth
-- ukm ra rồi,đúng gòi
-- hihi

Lời giải 2 :

Do có việc nên giờ mới gởi, xin lỗi bạn nha.

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

Có lỗi thì nói mình nhé.

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

program Hello;
uses crt;
var n,i,min,m,j:longint;
    a:array[1..10000] of longint;
begin
    write('Nhap n: ');
    readln(n);
    for i:= 1 to n do
        begin
            read(a[i]);
            for j:= 1 to n do
                if a[i] < a[j] then
                    begin
                        m:=a[i];
                        a[i]:=a[j];
                        a[j]:=m;
                    end;
        end;
    for i:= 1 to n do
        if a[i]-a[i-1]>1 then
            begin
                write(a[i-1]+1);
                break;
            end;
end.

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

Giải thích:

Mình sẽ sắp xếp lại mảng theo thứ tự từ nhỏ đến lớn.

Sau đó lấy phần tử sau trừ phần tử trước nếu lớn hơn 1 thì ghi phần tử trước cộng thêm 1.

Ví dụ:

n = 3

2 1 5 => 1 2 5 

5 - 2 = 3 > 1 => 2+1 = 3. 

image
image

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