zl程序教程

您现在的位置是:首页 >  Java

当前栏目

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

2023-03-07 09:06:11 时间

目录

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]));
        }
    }
}