Trang chủ Tin Học Lớp 9 Câu 2: Kiểm tra Một biểu thức số học chứa...

Câu 2: Kiểm tra Một biểu thức số học chứa dấu mở ngoặc ‘(‘ và đóng ngoặc ‘)’ xác định một cách đặt ngoặc đúng, nếu thỏa mãn các điều kiện sau: - Tổng số ngoặc

Câu hỏi :

Câu 2: Kiểm tra Một biểu thức số học chứa dấu mở ngoặc ‘(‘ và đóng ngoặc ‘)’ xác định một cách đặt ngoặc đúng, nếu thỏa mãn các điều kiện sau: - Tổng số ngoặc đóng = tổng số ngoặc mở - Đi từ trái qua phải, ở bất cứ vị trí nào số ngoặc đóng phải nhỏ hơn hoặc bằng số ngoặc mở Yêu cầu: Em hãy xác định một biểu thức số học có phải là một cách đặt ngoặc đúng không? Dữ liệu : vào từ tệp kiemtra.inp có cấu trúc như sau: - Dòng đầu là số test n (0<n<100). - N dòng tiếp theo, mỗi dòng là một dãy các biểu thức số học. Kết quả: ghi ra tệp kiemtra.out gồm n dòng, mỗi dòng là kết quả của một test tương ứng, xuất “YES” nếu cách đặt ngoặc đúng, ngược lại xuất “NO” Ví dụ: KIEMTRA.INP KIEMTRA.OUT 3 2(3+5) YES (2x+1)(4y+2) YES (2x-1))(3y-2) NO

Lời giải 1 :

var s:string;
    i,n:byte;
    f1,f2:text;
function check():boolean;
var d,d1,i:byte;
begin
   d:=0;d1:=0;
   for i:=1 to length(s) do
     begin
         if s[i]='(' then inc(d);
         if s[i]=')' then inc(d1);
         if d1>d then exit(false);
     end;
   if d1<>d then exit(false);
   exit(true);
end;
begin
   assign(f1,'KIEMTRA.INP');reset(f1);
   assign(f2,'KIEMTRA.OUT');rewrite(f2);
   readln(f1,n);
   for i:=1 to n do
      begin
          readln(f1,s);
          if check()=true then writeln(f2,'YES')
             else writeln(f2,'NO');
      end;
   close(f1),close(f2);
end.

Thảo luận

-- var s :ansistring; function kt():boolean; var t1,t2,i : longint; begin t1 := 0; t2 := 0; for i := 1 to length(s) do begin if s[i] = '(' then inc(t1); if s[i] = ')' then inc(t2); if t2 > t1 then exit(false); end; if t2 <> t1 then exit(false); exit(t... xem thêm
-- nhìn cũng ok nhỉ :)))))))
-- đc phết :v

Lời giải 2 :

uses crt;
var f,f1:text; i,n,d,g:longint; s,t:string; 
begin
clrscr;
   assign(f,'input.pas');reset(f);
   assign(f1,'output.pas');rewrite(f1);
      readln(f,n);
      for g:=1 to n do  
         begin
            readln(f,t); s:='';
            for i:=1 to length(t) do 
               if (t[i]='(')or(t[i]=')') then s:=s+t[i];
            repeat
               d:=0;
               for i:=1 to length(s)-1 do 
                  if (s[i]='(')and(s[i+1]=')') then begin inc(d); delete(s,i,2); end;
            until d=0; 
            if s='' then writeln(f1,'YES') else writeln(f1,'NO'); 
         end; 
   close(f1);        
   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ự 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 :))

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

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

Copyright © 2021 HOCTAPSGK