所以我已经连续 10 个小时尝试编写这个加密程序,我认为我快要完成了,但我已经碰壁了。
当我用单个单词写时,一切正常,但是当我试图加密句子时,它就搞砸了。原因是当单词之间有空格时,不应该进行加密。我想我可以通过添加来轻松解决这个问题
if(vektor[k]== ' ') {
k++;
}
我背后的想法是它检查 [k] 是否是空格,如果是,我将 +1 添加到 k,所以我跳到数组中的下一个插槽。但是我得到了 errormsg java.lang.ArrayIndexOutOfBoundsException
,我认为这意味着我正在尝试在数组中寻找一个不存在的插槽,但我不知道它为什么这样做。
这是我的代码,希望它就是所需要的。
int k=0;
int Q=0;
while(x>0){
if(Q>4){
Q=0; //resettar keyn till första bokstaven igen (räknar till 1-5)
}
vektor[k]=(char) (v[Q]+vektor[k]);
if(vektor[k]>90){
// System.out.println("STÖRRE ÄN 90 RESET");
vektor[k]=(char)(vektor[k]-26);
}
Q++;
System.out.print(vektor[k]);
x--;
k++;
if(vektor[k]== ' '){
vektor[k]='Ö';
k++;
}
}
编辑
我决定添加一个新变量以确保我没有尝试脱离向量。当它开始工作时,我很高兴。但是当我尝试用两个空格加密文本时,加密失败。所以我想是的,我只需将 if(vektor[k]== ' ') 更改为一段时间。但由于某种原因它不起作用,我再次得到数组外错误。
这是我现在的代码,只要你在单词之间只有一个'',它就可以工作。
int y=x;
int k=0;
int Q=0;
while(x>0 && y>k){ //hur funkar y>k delen xDDDDD
if(vektor[k]== ' '){
k++;
}
if(Q>4){
Q=0; //resettar keyn till första bokstaven igen (räknar till 1-5)
}
vektor[k]=(char) (v[Q]+vektor[k]);
if(vektor[k]>90){
// System.out.println("STÖRRE ÄN 90 RESET");
vektor[k]=(char)(vektor[k]-26);
}
Q++;
System.out.print(vektor[k]);
x--;
k++;
}