我是java的新手并且还在学习,所以请记住这一点。我正在尝试编写一个程序,用户可以在其中输入关键字,然后将其转换为数字并将其放入数组中。我的问题是数组需要不断重复int。
我的代码是:
String keyword=inputdata.nextLine();
int[] key = new int[keyword.length()];
for (int k = 0; k < keyword.length(); ++k)
{
if (keyword.charAt(k) >= 'a' && keyword.charAt(k) <= 'z')
{
key[k]= (int)keyword.charAt(k) - (int)'a';
}
}
现在,如果我尝试使任何key[i]
高于keyword.length
,则会引发outofbounds
错误。我需要它才能成为infinte。
所以基本上,如果keyword.length()
为3,我需要能够看到key[2]
是否与key[5]
和key[8]
相同,依此类推。
感谢您的帮助!
答案 0 :(得分:4)
嗯,首先通过一些重构来修复代码是最容易的。将keyword.charAt(k)
的所有用法提取到局部变量:
for (int k = 0; k < keyword.length(); ++k)
{
char c = keyword.charAt(k);
if (c >= 'a' && c <= 'z')
{
key[k] = c'a';
}
}
然后我们可以使用%
运算符解决问题:
// I assume you actually want a different upper bound?
for (int k = 0; k < keyword.length(); ++k)
{
char c = keyword.charAt(k % keyword.length());
if (c >= 'a' && c <= 'z')
{
key[k] = c - 'a';
}
}
这假设您实际上使key
长于keyword
- 并且您可能也想要更改循环的上限。例如:
int[] key = new int[1000]; // Or whatever
for (int k = 0; k < key.length; ++k)
{
char c = keyword.charAt(k % keyword.length());
if (c >= 'a' && c <= 'z')
{
key[k] = c - 'a';
}
}