2022西北农林科技大学信息工程学院阶段一B

Problem B 字符循环加密

题目描述

编写函数Encryption,实现对字母ch循环加密,要求其原型为:

仅需提交题目所要求的函数原型对应的函数定义源代码,不可提交测试用main函数及其它代码,否则会出现编译错误

        char Encryption(char ch, int k);

   其中:形参ch为待加密字母。形参k为字母加密偏移量。返回加密后的字母。

   加密算法为:如果ch为字母,则在由A-Z或a-z顺序构成的环形结构中,将字母ch循环右移k个字母,得到加密后的字母并将加密结果返回。若ch为其它字符,则不做任何变换,直接返回字母ch。对待加密字母需要区分大小写。

   提示:例如,'a'右移3个字母则加密结果为'd','x'右移3个字母则加密结果为'a'。可以通过将字母的ASCII值加偏移量后与26求余运算实现该操作。

#include<stdio.h>
char Encryption(char ch, int k);
char Encryption(char ch, int k){
    if(k>=26)
        k=k%26;
    if((ch>='a' && ch<='z') || (ch>='A' && ch <='Z')){
        ch=ch+k;
        if(ch>'z')
            ch=ch-'z'-1+'a';
        if(ch > 'Z' && ch < 'a')
            ch=ch-'Z'-1+'A';
        if((ch >= 'a' && ch <= 'z') || (ch>='A' && ch<='Z'))
            ch=ch;
    }
    else ch=ch;
    return ch;
}
int main(){
    char sh;
    int k;
    scanf("%c%d",&sh,&k);
    printf("%c",Encryption(sh,k));
}

追更:

上面的代码或许是错误的,因为我这个蒟蒻才发现,ASCII码也就是字符型一超过127就无法运算,所以ch=ch+k;或许ch会超过127;所以我们重新定义一个整型变量,利用int类型进行运算,最后再转为int型就可以了。看最终题解:

#include<stdio.h>
char Encryption(char ch, int k);
int sh;
char Encryption(char ch, int k){
    if(k>=26)
        k=k%26;
    if((ch>='a' && ch<='z') || (ch>='A' && ch <='Z')){
        sh=(int)ch+k;
        if(sh>122){
            sh=(int)sh-122-1+97;
            ch=(char)sh;
        }
        if(sh > 'Z' && sh < 'a')
            ch=sh-'Z'-1+'A';
        if((sh >= 'a' && sh <= 'z') || (sh >='A' && sh <='Z'))
            ch=sh;
    }
    else ch=ch;
    return ch;
}

over

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

511511511

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值