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