原始代码存在以下几方面的问题:
复比较,不仅效率低下,还使逻辑变得复杂。更合理的做法是对每个字符进行独立判断,并根据其类型采取相应的处理方式:
public class CaesarCipher {
public static String encrypt(String text, int shift) {
StringBuilder result = new StringBuilder();
for (char c : text.toCharArray()) {
if (Character.isUpperCase(c)) {
char encryptedChar = (char) (((c - 'A' + shift) % 26) + 'A');
result.append(encryptedChar);
} else if (Character.isLowerCase(c)) {
char encryptedChar = (char) (((c - 'a' + shift) % 26) + 'a');
result.append(encryptedChar);
} else {
result.append(c);
}
}
return result.toString();
}
public static void main(String[] args) {
String text = "Hello, World! 123";
int shift = 3;
String encryptedText = encrypt(text, shift);
System.out.println("Original text: " + text);
System.out.println("Encrypted text: " + encryptedText); // Output: Khoor, Zruog! 123
}}
代码说明:
本文提出了一种清晰高效的凯撒密码实现方式,解决了如何仅对字母加密而保留符号不变的问题。通过逐字符处理避免了冗余操作,提高了代码效率和可读性。同时提供了完整的解释和注意事项,帮助读者深入理解该加密方法。但请注意,凯撒密码属于基础加密技术,不具备实际应用的安全保障。