华为算法刷题 20 简单密码

描述

现在有一种密码变换算法。

九键手机键盘上的数字与字母的对应: 1--1, abc--2, def--3, ghi--4, jkl--5, mno--6, pqrs--7, tuv--8 wxyz--9, 0--0,把密码中出现的小写字母都变成九键键盘对应的数字,如:a 变成 2,x 变成 9.

而密码中出现的大写字母则变成小写之后往后移一位,如:X ,先变成小写,再往后移一位,变成了 y ,例外:Z 往后移是 a 。

数字和其它的符号都不做变换。

数据范围: 输入的字符串长度满足  1≤n≤100 

输入描述:

输入一组密码,长度不超过100个字符。

输出描述:

输出密码变换后的字符串

示例1

输入:YUANzhi1987

输出:zvbo9441987


希望机试能抽到


#include <stdio.h>
#include<string.h>

int main() {
    int i, len;
    char str[100];
    scanf("%[^\n]\n",str);
    len=strlen(str);
    for(i=0;i<len;i++)
    {
            if((str[i]>='a')&&(str[i]<='c'))
            {
                printf("2");
            }
            else if((str[i]>='d')&&(str[i]<='f'))
            {
                printf("3");
            }
            else if((str[i]>='g')&&(str[i]<='i'))
            {
                printf("4");
            }
            else if((str[i]>='j')&&(str[i]<='l'))
            {
                printf("5");
            }
            else if((str[i]>='m')&&(str[i]<='o'))
            {
                printf("6");
            }
            else if((str[i]>='p')&&(str[i]<='s'))
            {
                printf("7");
            }
            else if((str[i]>='t')&&(str[i]<='v'))
            {
                printf("8");
            }
            else if((str[i]>='w')&&(str[i]<='z'))
            {
                printf("9");
            }
            else if((str[i]>='A')&&(str[i]<='Y'))
            {
                printf("%c",str[i]+33);
            }
            else if(str[i]=='Z')
            {
                printf("a");
            }
            else {
                printf("%c",str[i]);
            }
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值