HW--字符串加解密
package t0817;
import java.util.Scanner; public class StringEncrypt {
public static void main(String[] args){
Scanner scanner_1 = new Scanner(System.in);
String str_1 = scanner_1.nextLine();
char chPass[]=str_1.toCharArray();
char chResu[]=new char[str_1.length()]; Scanner scanner_2 = new Scanner(System.in);
String str_2 = scanner_2.nextLine();
char chResu2[]=str_2.toCharArray();
char chPass2[]=new char[str_2.length()]; Encrypt(chPass,chResu);
System.out.println(chResu);
unEncrypt(chResu2,chPass2);
System.out.println(chPass2);
}
/*
* 在该函数中实现字符串加密并输出
*/
static void Encrypt (char aucPassword[], char aucResult[]){
for(int i=0;i<aucPassword.length;i++){
if(aucPassword[i]>='a'&&aucPassword[i]<='z'){ //小写字母后面一个(+1),再变大写字母(-32)
if(aucPassword[i]=='z')
aucResult[i]='A';
else
{
aucResult[i]=(char)(aucPassword[i]+1-32);
}
}
else if(aucPassword[i]>='A'&&aucPassword[i]<='Z'){ // 大写字母变小写
if(aucPassword[i]=='Z')
aucResult[i]='a';
else
{
aucResult[i]=(char)(aucPassword[i]+1+32);
}
}
else if(aucPassword[i]>='0'&&aucPassword[i]<='9'){ // 数字
if(aucPassword[i]=='9')
aucResult[i]='0';
else
aucResult[i]=(char)(aucPassword[i]+1);
}
else aucResult[i]=aucPassword[i]; //其他字符保持不变化 } }
/*
* 在该函数中实现字符串解密并输出
*/
static int unEncrypt (char result[], char password[]) {
for(int i=0;i<result.length;i++){
if(result[i]>='a'&&result[i]<='z'){ //小写字母变大写
if(result[i]=='a')
password[i]='Z';
else
{
password[i]=(char)(result[i]-32-1);
}
}
else if(result[i]>='A'&&result[i]<='Z'){ // 大写字母变小写
if(result[i]=='A')
password[i]='z';
else
{
password[i]=(char)(result[i]+32-1);
}
}
else if(result[i]>='0'&&result[i]<='9'){ // 数字
if(result[i]=='0')
password[i]='9';
else
password[i]=(char)(result[i]-1);
}
else password[i]=result[i]; //保持不变化 }// for循环
return 0;
}//j解码函数 }
题目描述 1、对输入的字符串进行加解密,并输出。 2加密方法为: 当内容是英文字母时则用该英文字母的后一个字母替换,同时字母变换大小写,如字母a时则替换为B;字母Z时则替换为a; 当内容是数字时则把该数字加1,如0替换1,1替换2,9替换0; 其他字符不做变化。 3、解密方法为加密的逆过程。 接口描述: 实现接口,每个接口实现1个基本操作: void Encrypt (char aucPassword[], char aucResult[]):在该函数中实现字符串加密并输出 说明: 1、字符串以\0结尾。 2、字符串最长100个字符。 int unEncrypt (char result[], char password[]):在该函数中实现字符串解密并输出 说明: 1、字符串以\0结尾。 2、字符串最长100个字符。 |
|
知识点 | 字符串 |
---|---|
运行时间限制 | 10M |
内存限制 | 128 |
输入 |
输入说明 |
输出 |
输出说明 |
样例输入 | abcdefg BCDEFGH |
样例输出 | BCDEFGH abcdefg |
HW--字符串加解密的更多相关文章
- android中使用jni对字符串加解密实现分析
android中使用jni对字符串加解密实现分析 近期项目有个需求.就是要对用户的敏感信息进行加密处理,比方用户的账户password,手机号等私密信息.在java中,就对字符串的加解密我们能够使用A ...
- iOS - (base64对字符串加解密)
今天公司让做支付系统,为了安全起见,需要对一些数据进行加密,然而我首想到的就是 base64 ,严格来说这不是一种加密方式,这只是将原有的一些字符串或者其它的一些文本进行一个转化而已,就是转化成数字, ...
- 华为OJ:字符串加解密
题目描述 1.对输入的字符串进行加解密,并输出. 2加密方法为: 当内容是英文字母时则用该英文字母的后一个字母替换,同时字母变换大小写,如字母a时则替换为B:字母Z时则替换为a: 当内容是数字时则把该 ...
- iOS开发:用DES对字符串加解密
参考http://www.cnblogs.com/janken/archive/2012/04/05/2432930.html,做了个小修改,实现PHP,JAVA,Objective-c加解密结果相同 ...
- C#常用字符串加解密方法封装
C#中常用的字符串加密.解密方法封装,包含只加密但不解密的方法.收藏起来备用. //方法一 //须添加对System.Web的引用 //using System.Web.Security; /// & ...
- C++ 简单字符串加解密(转载)
#include <iostream.h> #include <windows.h> #include <tchar.h> void EncodeString(LP ...
- 基于Crypto++的aes 字符串加解密实现
esaes.h: #ifndef ESAES_H #define ESAES_H #include <cryptopp/aes.h> #include <iostream> # ...
- Java 使用AES/CBC/PKCS7Padding 加解密字符串
介于java 不支持PKCS7Padding,只支持PKCS5Padding 但是PKCS7Padding 和 PKCS5Padding 没有什么区别要实现在java端用PKCS7Padding填充, ...
- Python用户名密码登录系统(MD5加密并存入文件,三次输入错误将被锁定)及对字符串进行凯撒密码加解密操作
# -*- coding: gb2312 -*- #用户名密码登录系统(MD5加密并存入文件)及对字符串进行凯撒密码加解密操作 #作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.co ...
- base64加解密字符串
import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.IOExceptio ...
随机推荐
- HDU1710Binary Tree Traversals
HDU1710Binary Tree Traversals 题目大意:给一个树的前序遍历和中序遍历,要求输出后序遍历. (半年前做这道题做了两天没看懂,今天学了二叉树,回来AC了^ ^) 首先介绍一下 ...
- VisualStudio2010中创建ASP.Net WebService
相关资料:http://blog.csdn.net/yapingxin/article/details/7331375 具体操作:1.打开“Microsoft Visual Studio 2010”- ...
- SQL2008-分页显示3种方法
方法1: 适用于 SQL Server 2000/2005/2008 SELECT TOP 10 * FROM YieldRole WHERE id NOT IN ( SELECT TOP (10*( ...
- CentOS6.5安装nginx及负载均衡配置
所有的安装包可以去以下地址下载,或者自行去官网下载,下面都有介绍. 所有安装包地址:http://download.csdn.net/detail/carboncomputer/9238037 原文地 ...
- SQL Server里一些未公开的扩展存储过程
SQL Server里一些未公开的扩展存储过程 [转帖] 博客天地 www.inbaidu.com SQL Server里一些未公开的扩展存储过程 扩展存储过程(xp)是直接运行在SQL Server ...
- Parameterized Path 的例子
Improve the planner's ability to use nested loops with inner index scans (Tom Lane) The new "pa ...
- 【转】SQL语句中的正则表达示
正则表达式作用是匹配方本,将一个模式(正则表达式)与一个文本串进行比较. MySQL用WHERE子句对正则表达式提供了初步的支持,允许你指定用正则表达式过滤SELECT检索出的数据. MySQL仅支持 ...
- hdu 5446 Unknown Treasure lucas和CRT
Unknown Treasure Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?p ...
- leetcode解决问题的方法||Integer to Roman问题
problem: Given an integer, convert it to a roman numeral. Input is guaranteed to be within the range ...
- android4.4短信新概念
android4.4对短信引入了一个全新的概念:默认短信应用.即android用户可以在系统设置里面选择一个默认的短信应用,只有这个应用才能进行手机的基本短信操作.按照google自己的解释这样做的原 ...