C 언어 는 암호 화 복호화 기능 을 실현 한다.
먼저 카 이 저 암호 화 에 대해 말씀 드 리 겠 습 니 다.카 이 저 비밀 번 호 는 고대 로마 카 이 저 대제 가 중요 한 군정 을 보호 하 는 암호 화 시스템 이 라 고 전해 집 니 다.그것 은 알파벳 순 서 를 뒤로 미 루 는 암호 화 작용 을 하 는 암호 화 된 암호 화 장치 이다.알파벳 순 서 를 3 자리 뒤로 미 루 면 알파벳 A 는 알파벳 D 로,알파벳 B 는 알파벳 E 로 밀 린 다.이 인 스 턴 스 는 카 이 저 암호 화 와 유사 합 니 다.
암호 화 알고리즘:
큰(작은)자 모 를 암호 화한 후에 도 큰(작은)자 모 를 쓴다.큰(작은)자 모 는 n 자리 로,n 은 사용자 가 입력 하고,큰(작은)자모의 ASCII 범 위 를 넘 으 면 첫 번 째 큰(작은)글자 로 되 돌아 가 계속 순환한다.
복호화 알고리즘(암호 화 알고리즘 과 정반 대):
큰(작은)자 모 를 복호화 한 후에 도 큰(작은)자 모 를 쓴다.큰(작은)자 모 는 n 자 리 를 앞으로 밀어 주 고 n 은 사용자 가 입력 하 며 큰(작은)자모의 ASCII 범 위 를 넘 으 면 마지막 큰(작은)글자 로 되 돌아 가 계속 순환 합 니 다.
코드 는 다음 과 같 습 니 다:
/*              */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
//  encode()       n ,        
void encode(char str[],int n){
 char c;
 int i;
 for(i=0;i<strlen(str);++i){ //     
 c=str[i];
 if(c>='a' && c<='z'){ //c     
  if(c+n%26<='z'){ //             
  str[i]=(char)(c+n%26); //    
  }else{ //           ,          
  str[i]=(char)(c+n%26-26);
  }
 }else if(c>='A' && c<='Z'){ //c     
  if(c + n%26 <= 'Z'){ //            
  str[i]=(char)(c+n%26);
  }else{ //           ,          
  str[i]=(char)(c+n%26-26);
  }
 }else{ //    ,   
  str[i]=c;
 }
 }
 printf("
After encode: 
");
 puts(str); //         
}
 
 
//decode()      ,       n 
void decode(char str[],int n){
 char c;
 int i;
 //     
 for(i=0;i<strlen(str);++i){
 c=str[i];
 //c     
 if(c>='a' && c<='z'){
  //         ,    
  if(c-n%26>='a'){
  str[i]=(char)(c-n%26);
  }else{
  //          ,               
  str[i]=(char)(c-n%26+26);
  }
 }else if(c >= 'A' && c<='Z'){ //c     
  if(c-n%26>='A'){ //         
  str[i]=(char)(c-n%26);
  }else{ //          ,      ,       
  str[i]=(char)(c-n%26+26);
  }
 }else{ //      
  str[i]=c;
 }
 }
 printf("
After decode: 
");
 puts(str); //         
}//        ,     
 
int main()
{
 char str[50];
 int k=0,n=0,i=1;
 printf("
Please input strings: ");
 scanf("%s",str); //         
 //    
 printf("-----------------
");
 printf("1: Encryption
");
 printf("2: Decryption
");
 printf("3: Violent Crack
"); //    
 printf("-----------------
");
 printf("
Please choose: ");
 scanf("%d",&k);
 if(k==1){ //  
 printf("
Please input number: ");
 scanf("%d",&n);
 encode(str,n);
 }else if(k==2){ //  
 printf("
Please input number: ");
 scanf("%d",&n);
 decode(str,n);
 }else{
 for(i=1;i<=25;++i){ //       n       
  printf("%d ",i);
  decode(str,i);
 }
 }
 return 0;
}테스트 실행 은 다음 과 같 습 니 다:
 암호 화 복호화 기능 을 성공 적 으로 실현 하면 독 자 는 파일 에 대한 암호 화 복호화 를 약간 개조 할 수 있다.
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
C 언어 체인 시계는 뱀을 탐식하는 작은 게임을 실현한다본고의 실례는 여러분에게 C 언어 체인표가 뱀 탐식 게임을 실현하는 구체적인 코드를 공유하여 참고하도록 하였으며, 구체적인 내용은 다음과 같다. 프로젝트 이름: 뱀놀이 운영 환경: Linux 프로그래밍 언어: C 언...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.