因此,我尝试从用户输入的字母中提取一个字母,然后找到距离 10个字母的字母,我希望如果字母是'z'或'y'或<字母16的任何东西,请环绕字母。
我正在努力处理循环部分。我知道字母只是被扔到ASCII table
中,而数字不是1-26,所以我不确定如何处理它。这就是我到目前为止所拥有的。
public static void main(String[] args){
Scanner input = new Scanner(System.in);
System.out.println("Please input your favorite letter");
char userLetter = input.next().charAt(0);
char newLetter = (char) ((userLetter + 10) % 26);
System.out.println("10 letters beyond your letter is " + newChar);
}
有人可以帮忙吗?
答案 0 :(得分:1)
我们可以尝试将小写和大写字母字符映射到1-26比例,然后进行移位并可能使用模数进行换行。最后,我们跟踪移位量,以便可以将其重新添加以生成移位字符。
Scanner input = new Scanner(System.in);
System.out.println("Please input your favorite letter");
char userLetter = input.next().charAt(0);
// get the ASCII value of the input character
int ascii = (int) userLetter;
// compute the shift (97 for lowercase, 65 for uppercase)
int shift = ascii > 90 ? 97 : 65;
int newPosition = (ascii - shift + 10) % 26;
newPosition += shift;
char newChar = (char) newPosition;
System.out.println("10 letters beyond your letter is " + newChar);
答案 1 :(得分:0)
相反,您可以只使用valueOf组合。
String userLetter = ...;
int charValue = userLetter.charAt(0);
String next = String.valueOf((char)(charValue + 10));
然后只是一个if语句,以检测它何时到达A或Z并相应地对其进行更改。
希望这会有所帮助。
答案 2 :(得分:0)
它称为CaesarCipher s是您的班次计数
//A Java Program to illustrate Caesar Cipher Technique
public class CaesarCipher
{
// Encrypts text using a shift od s
public static StringBuffer encrypt(String text, int s)
{
StringBuffer result= new StringBuffer();
for (int i=0; i<text.length(); i++)
{
if (Character.isUpperCase(text.charAt(i)))
{
char ch = (char)(((int)text.charAt(i) +
s - 65) % 26 + 65);
result.append(ch);
}
else
{
char ch = (char)(((int)text.charAt(i) +
s - 97) % 26 + 97);
result.append(ch);
}
}
return result;
}
// Driver code
public static void main(String[] args)
{
String text = "ATTACKATONCE";
int s = 10;
System.out.println("Text : " + text);
System.out.println("Shift : " + s);
System.out.println("Cipher: " + encrypt(text, s));
}
}
答案 3 :(得分:0)
尝试一下:
public static void main(String[] args) {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
System.out.println("Please input your favorite letter");
char userLetter = input.next().charAt(0);
int unumber = (int) userLetter;
int newNum=unumber+10;
if(newNum>122 || newNum>90){
newNum=(unumber)-(26-10);
}
char newLetter = (char) (newNum);
System.out.println("10 letters beyond your letter is " + newLetter);
}