Trang chủ Tin Học Lớp 9 Cho xâu X độ dài không quá 1000, chỉ chứa...

Cho xâu X độ dài không quá 1000, chỉ chứa các kí tự trong tập {‘?’, ‘A’, ..., ‘Z’}. Trong đó, mỗi kí tự ‘?’ có thể được thay bằng một trong các kí tự ‘A’, ...,

Câu hỏi :

Cho xâu X độ dài không quá 1000, chỉ chứa các kí tự trong tập {‘?’, ‘A’, ..., ‘Z’}. Trong đó, mỗi kí tự ‘?’ có thể được thay bằng một trong các kí tự ‘A’, ..., ‘Z’. Ví dụ xâu ‘A?DA’, ta có thể tạo được các xâu ‘AADA’, ‘ABDA’, ‘ACDA’, ‘ADDA’, ... ‘AZDA’. Trong đó xâu ‘ADDA’ là xâu đối xứng. Yêu cầu: cho xâu X. Hãy tìm xâu đối xứng có thứ tự từ điển nhỏ nhất có thể tạo được từ X. Dữ liệu vào: từ file XAU.INP • Gồm nhiều dòng, mỗi dòng chứa xâu X. Số dòng không quá 100 Kết quả: ghi vào file văn bản XAUDX.OUT • Gồm nhiều nhiều dòng, mỗi dòng là xâu tìm được hoặc ghi ra -1 nếu không tìm được. Ví dụ XAUDX.INP DF????D AKD? XAUDX.OUT DFAAAFD -1

image

Lời giải 1 :

uses crt;
var n,i,kt:longint; d:text; s:string;
function dx(a:string):boolean;
   var i:longint;
      begin
         for i:=1 to n do If a[i]<>a[n-i+1] then exit(false);
         exit(true);
      end;
begin
clrscr;
assign(d,'input.pas');reset(d);
readln(d,s); n:=length(s);
assign(d,'output.pas');rewrite(d);
for i:=1 to n do
   begin
      If (s[i]='?')and(s[n-i+1]<>'?') then s[i]:=s[n-i+1];
      If (s[i]='?')and(s[n-i+1]='?') then s[i]:='A';
   end;
kt:=1;
for i:=1 to n do If s[i]='?' then kt:=0;
If (kt=0)or(not(dx(s))) then writeln(d,'-1') else writeln(d,s);
close(d);
readln
end.

Mình thử nhiều text thấy đúng, mong bạn vote cho mình nha

Thảo luận

-- vote cho bạn nha
-- Cảm ơn nha
-- n là j v bạn ơi
-- e vào nhóm đc k

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