题目内容:
对数字求特征值是常用的编码算法,奇偶特征是一种简单的特征值。对于一个整数,从个位开始对每一位数字编号,个位是1号,十位是2号,以此类推。这个整数在第n位上的数字记作x,如果x和n的奇偶性相同,则记下一个1,否则记下一个0。按照整数的顺序把对应位的表示奇偶性的0和1都记录下来,就形成了一个二进制数字。比如,对于342315,这个二进制数字就是001101。
思路:可不可以这样。先一个循环不断除以10,最后小于10大于0时停止,然后与累计除10的次数number相加除2取余,若为0则使用math.pow函数。Math.pow(2,number)否则为0.接着继续循环,好像不行。因为这样后面的数好像就没法解决了。至少以我目前的水平无法解决。
那我们接着想,这样:
先取余得到个位数,然和将个位数与1相加除2取余if判断是否等于0.如果是那么使用math.pow函数计算(2,number-1),每循环一次,number的值加一,number++.然后除10,再判断个位数。以此循环。这个好像可以,形象地比喻为切萝卜片,切下一片处理一片。
import java.util.Scanner;
public class Main{
public static void main(String[] args)
{
Scanner a=new Scanner(System.in);
int n =a.nextInt();
int single;//个位数的值
int number=0;//位数
int s=0;//计算的值
while (n>0)
{
single=n%10;
number++;
if((single+number)%2==0)//相加是否是偶数,既比较位数和位数上的数奇偶是否一致
{
s+=Math.pow(2, number-1);
}
n=n/10;
}
System.out.println(s);
}
}