登录
首页 >  文章 >  java教程

Java字符数组实现简易凯撒密码教程

时间:2026-04-17 15:15:40 179浏览 收藏

本文手把手教你用Java的char数组实现一个轻量级凯撒密码加密器:通过将明文转为字符数组,遍历每个字符并智能判断大小写,利用ASCII码基准('a'/'A')和模26运算安全完成字母循环移位(如z+3→c),非字母字符原样保留,既清晰展现了底层字符处理逻辑,又兼顾了边界处理与代码可读性,是理解字符串加密原理与数组操作的绝佳入门实践。

如何利用char类型数组配合循环在Java中实现简易凯撒密码

char 类型数组配合循环实现凯撒密码,核心是把每个字母按固定偏移量(如 +3)平移,非字母字符保持不变。关键在于区分大小写、处理字母边界(如 'z' + 3 应回到 'c'),并用数组存取字符便于逐个修改。

准备字符数组与偏移量

先将明文字符串转为 char[],方便循环中直接修改;定义一个整数偏移量(如 key = 3),它决定每个字母移动几位。

例如:

String plain = "Hello";
char[] chars = plain.toCharArray(); // 得到 ['H', 'e', 'l', 'l', 'o']
int key = 3;

遍历数组并逐个加密

对数组每个元素判断是否为英文字母:是则计算新字符,否则跳过。大小写字母要分别处理,因为它们的 ASCII 范围不同('A'–'Z' 是 65–90,'a'–'z' 是 97–122)。

计算逻辑(以小写为例):

  • 先减去 'a'(即 97),把 'a'→0, 'b'→1, …, 'z'→25
  • 加上 key 后对 26 取模(防止越界,如 25 + 3 = 28 → 28 % 26 = 2 → 'c')
  • 再加上 'a',还原成对应字母 ASCII 值

大写字母同理,用 'A' 作基准。

完整加密循环示例

以下是在循环中更新 chars[i] 的典型写法:

for (int i = 0; i   char c = chars[i];
  if (c >= 'a' && c     chars[i] = (char) ((c - 'a' + key) % 26 + 'a');
  } else if (c >= 'A' && c     chars[i] = (char) ((c - 'A' + key) % 26 + 'A');
  }
  // 其他字符(空格、数字、标点)不处理
}

最后用 new String(chars) 转回字符串即可得到密文。

解密只需反向偏移

解密时把 + key 换成 - key,但注意负数取模问题。更稳妥写法是:

(c - 'a' - key + 26) % 26 + 'a'

加 26 确保被模数非负,再取模,避免 Java 中负数取模结果为负。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Java字符数组实现简易凯撒密码教程》文章吧,也可关注golang学习网公众号了解相关技术文章。

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>