6-4 字符串加密(Java解法,两种网上的类型题)

举报
红目香薰 发表于 2023/01/23 17:29:22 2023/01/23
1k+ 0 0
【摘要】 ​ 目录6-4字符串加密,第一种类型题:Java题解1:字符串加密,第二种类型题:Java题解2:6-4字符串加密,第一种类型题:        本题要求实现一个函数,能对一行字符串(字符串的长度<80)加密。 加密函数采用的加密算法:如果不是英文字母,就不加密,原样显示;否则就将字母加上一个偏移值5实现加密。        注意大小写英文字母分别构成一个封闭环,如字符‘w’,加密后为字符‘...

 目录

6-4字符串加密,第一种类型题:

Java题解1:

字符串加密,第二种类型题:

Java题解2:


6-4字符串加密,第一种类型题:

        本题要求实现一个函数,能对一行字符串(字符串的长度<80)加密。 加密函数采用的加密算法:如果不是英文字母,就不加密,原样显示;否则就将字母加上一个偏移值5实现加密。

        注意大小写英文字母分别构成一个封闭环,如字符‘w’,加密后为字符‘b’。

Java题解1:

这个是第一个类型的,有一个测试样例

输入样例:

Hello World!

输出样例:

Mjqqt Btwqi!

编码过程 

package com.item.action;

import java.util.Scanner;

public class Main1 {

	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		String s = sc.nextLine();
		sc.close();
		char[] cs = cryptograp(s.toCharArray(), s.length());
		for (char c : cs) {
			System.out.print(c);
		}
	}

	private static char[] cryptograp(char[] ch, int n) {
		// TODO Auto-generated method stub
		for (int i = 0; i < n; i++)// u v w x y z;
		{
			if (ch[i] >= 'a' && ch[i] <= 'u')
				ch[i] = (char) (ch[i] + 5);
			else if (ch[i] >= 'v' && ch[i] <= 'z')
				ch[i] = (char) ('a' + ch[i] - 'v');
			if (ch[i] >= 'A' && ch[i] <= 'U')
				ch[i] = (char) (ch[i] + 5);
			else if (ch[i] >= 'V' && ch[i] <= 'Z')
				ch[i] = (char) ('A' + ch[i] - 'V');
		}
		return ch;
	}

}

编辑

字符串加密,第二种类型题:

        输入一个原始字符串(长度小于80)(在这里看和第一个题类似),然后输入一个5位的数字字符串作为加密密钥,对原始字符串中的每个字符根据其位置(对5取模)变换为加上数字字符串中的数字的字符。如输入原始字符串student,然后输入5位的加密数字12345,因此:

原始字符 加密数字 变换后的字符
s 1 t
t 2 v
u 3 x
d 4 h
e 5 j
n 1 o
t 2 v
加密后的字符串位:tvxhjov

输入格式: 第一个输入一个原始字符串 第二行输入一个5位用来加密的数字字符串

输出格式: 加密后的字符串

输入样例1:

在这里给出一组输入。例如:

student
12345

结尾无空行

输出样例1:

在这里给出相应的输出。例如:

tvxhjov

结尾无空行

输入样例2:

在这里给出一组输入。例如:

Welcome to Java!
10932

结尾无空行

输出样例2:

在这里给出相应的输出。例如:

Xeufqne)wq!Jjyc"

Java题解2:

package com.item.action;
import java.util.*;

public class Main{
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String s=sc.nextLine();
        int k=sc.nextInt();
        sc.close();
        cryptograp(s.toCharArray(), k);
    }
    private static void cryptograp(char ch[],int n) {
    	int a[]=new int[5];
        for(int i=a.length-1;i>=0;i--) {
            a[i]=n%10;
            n=n/10;
        }
        for(int i=0;i<ch.length;i++) {
            System.out.print((char)(ch[i]+a[i%5]));
        }
    }
}

【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

作者其他文章

评论(0

抱歉,系统识别当前为高风险访问,暂不支持该操作

    全部回复

    上滑加载中

    设置昵称

    在此一键设置昵称,即可参与社区互动!

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

    *长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。