前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >6-4 字符串加密(Java解法,两种网上的类型题)

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

作者头像
红目香薰
发布2023-02-10 10:06:05
2810
发布2023-02-10 10:06:05
举报
文章被收录于专栏:CSDNToQQCodeCSDNToQQCode

目录

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

Java题解1:

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

Java题解2:


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

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

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

Java题解1:

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

输入样例:

代码语言:javascript
复制
Hello World!

输出样例:

代码语言:javascript
复制
Mjqqt Btwqi!

编码过程 

代码语言:javascript
复制
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:

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

代码语言:javascript
复制
student
12345

结尾无空行

输出样例1:

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

代码语言:javascript
复制
tvxhjov

结尾无空行

输入样例2:

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

代码语言:javascript
复制
Welcome to Java!
10932

结尾无空行

输出样例2:

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

代码语言:javascript
复制
Xeufqne)wq!Jjyc"

Java题解2:

代码语言:javascript
复制
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]));
        }
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-01-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 6-4字符串加密,第一种类型题:
  • Java题解1:
  • 字符串加密,第二种类型题:
  • Java题解2:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档