Chuyển đến nội dung chính

MÃ HÓA CAESAR

MÃ HÓA CAESAR
Hệ mã hoá CAESAR là một hệ mã hoá thay thế đơn làm việc trên 
bảng chữ cái tiếng Anh 26 ký tự (A, B, ... , Z).
Trong hệ CAESAR và các hệ tương tự còn lại ta sử dụng các số tự 
nhiên thay cho các ký tự - đánh số các ký tự trong bảng chữ cái theo thứ 
tự: A là 0, B là 1,...và Z là 25. 
A B C D ... L M N ... W X Y Z

0 1 2 3 ... 11 12 13 ... 22 23 23 25 

Mã hóa caesar bằng Pascal

uses crt;
var s : string;
    i,k : byte;
Function caesar(c: char; k: byte) : char;
var tmp : byte;
Begin
   if (upcase(c) in ['A'..'Z']) then
      Begin
        tmp := ord(upcase(c)) + k;
        if (tmp > 90) then tmp := tmp - 26;
        exit(char(tmp));
      End
    else exit(c);
End;
Begin
   clrscr();
   writeln('Nhap chuoi can ma hoa');
   readln(s);
   writeln('Nhap K = ');
   readln(k);
   for i := 1 to length(s) do
        s[i] := caesar(s[i],k);
   writeln('Chuoi da ma hoa: ');
   writeln(s);
   readln();
End.

Nhận xét

Bài đăng phổ biến từ blog này

DÃY ĐAN DẤU TRONG PASCAL

DÃY ĐAN DẤU TRONG PASCAL Dãy đan dấu là dãy không có 2 phần tử cạnh nhau có dấu giống nhau. ví dụ: -2 4 -9 5 -23 8 là dãy đan dấu Thủ tục kiểm tra dãy đan dấu trong dãy số: procedure dandau; var i,j:integer;     kt:boolean; begin kt:=true; for i:=1 to N-1 do                 begin                 j:=i+1;                 if a[i] *a[j] >0 then kt:=false;                 end; If kt=true then write('Day A la day dan dau') else write('Day A khong phai day dan dau'); end;

Tam giác số (Pascal)

TAM GIÁC SỐ  (Câu 4. Hội thi Tin Học Trẻ Phú Yên lần thứ XIX - năm 2016)                              7                          3       8                      8      1       0                   2     7        4       4                 4    5      2       6       5 Cho một tam giác gồm các số nguyên không âm (xem hình trên). Hãy viết chương trình tính tổng lớn nhất của các số nằm trên lộ trình từ đỉnh xuống: - Tại mỗi bước đi, lộ trình có thể đi xuống phía bên trái hoặc xuống phía bên phải. - Số hàng trong tam giác lớn hơn...

VÒNG LẶP KHÔNG XÁC ĐỊNH WHILE..DO; REPEAT .. UNTIL

VÒNG LẶP KHÔNG XÁC ĐỊNH  WHILE..DO; REPEAT .. UNTIL - Vòng lặp While..do While <điều kiện > Do  <câu lệnh>; Câu lệnh sau do được thực hiện khi điều kiện được thỏa mãn (điều kiện =true); vòng lặp kết thúc khi điều kiện không thỏa (điều kiện =false) - Vòng lặp Repeat .. until; Repeat <câu lệnh>; Until <điều kiện>; Lặp lại câu lệnh cho đến khi nào  thỏa mãn điều kiện  (điều kiện =true) thì dừng lại;  Bài tập: Nhập vào một số nguyên A thỏa mãn (0<A<100), Tính tổng các số nguyên từ 1 đến A (S=1+2+...+A). Vận dụng câu lệnh While .. do uses crt; var A,I:  Integer; S:longint; begin          a:=0;          while not ((a>0) and (a<100)) do          begin          write('Nhap gia tri cua A:'); read(A);           end;          s:=0...