任务是使用一个循环生成,模运算符生成以下模式。
12345 23451 34512 45123 51234
我确实有一个解决方案,但我认为它没有得到很好的解决。所以我正在寻找一种更优雅的方法来解决问题,而不会损害要求。
class Test{
public static void main(String[] args){
int num = 12345;
System.out.println(num);
for(int i = 0; i < 4; i++){
int tmp = num%10000+21106+i;
System.out.println(tmp);
}
}
}
你需要用/ 10000 and
提取第一个(最重要的)数字,其余数字用% 10000
。然后你可以构建系列中的下一个数字。
public static void main(String[] args){
int num = 12345;
System.out.println(num);
for(int i = 0; i < 4; i++) {
int first = num / 10000;
int last4 = num % 10000;
num = last4 * 10 + first;
System.out.println(num);
}
}
Eran的answer是正确的,但硬编码的顺序(它只适用于10000-99999范围内的数字)。但是,我们可以通过注意数字的长度(十进制)等于数字的log10来概括它。就像是
int num = 123456;
System.out.println(num);
int log10 = (int) Math.log10(num);
for (int i = 0; i < log10; i++) {
int pow10 = (int) Math.pow(10, log10);
int first = num / pow10;
int last4 = num % pow10;
num = last4 * 10 + first;
System.out.println(num);
}