C和指针_编程练习_第9章_第14题

/*
        这个问题的最后部分就是编写函数:
        void decrypt( char *data, char const *key );

        它接受一个加密过的字符串为参数, 它的任务是重现原来的信息. 除了它是用于揭秘之外, 它的工作原理应该与encrypt 相同
*/


void decrypt( char *data, char const *key )
{
        /* offset: data 中某个字母在key 中的偏移量( 即下标 ) */
        char offset;
        char const *const keyMark = key;

        /*
         * 遍历data, 直到遇见NUL字符
         *
         * 如果data 中某个字符是大写字母, 记作原字母, 就遍历key 直到遇见原字母对应的小写字母形式, 记下这个小写字母在key 中的偏移量offset
         * 'A' + offset 就是解密后的字母
         *
         * 如果data 中某个字符是小写字母, 记作原字母, 就遍历key 直到遇见原字母, 记下原字母在key 中的偏移量offset
         * 'a' + offset 就是解密后的字母
         *
         * 如果data 中某个字符既不是大写字母, 又不是小写字母, 无需解密
         */
        for( ; *data != '\0'; ++data )
        {
                if( *data >= 'A' && *data <= 'Z' )
                {
                        for( key = keyMark, offset = 0; *key != *data + 32; ++key )
                        {
                                ++offset;
                        }

                        *data = 'A' + offset;
                }

                else if( *data >= 'a' && *data <= 'z' )
                {
                        for( key = keyMark, offset = 0; *key != *data; ++key )
                        {
                                ++offset;
                        }

                        *data = 'a' + offset;
                }
        }

        return;
}


#include <stdio.h>

int main( void )
{
        char data_1[] = "TPPTAD TP ITVH";
        char *key = "trailbzescdfghjkmnopquvwxy";

        printf( "密钥key: %s\n\n", key );

        printf( "解密前: %s\n", data_1 );
        decrypt( data_1, key );
        printf( "解密后: %s\n\n", data_1 );

        char data_2[] = "Tff thsgtfo tnl lmqtf, rqp ojgl thsgtfo tnl gjnl lmqtf peth jpelno!";
        printf( "解密前: %s\n", data_2 );
        decrypt( data_2, key );
        printf( "解密后: %s\n\n", data_2 );

        return 0;
}

程序运行结果:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值