使用移位操作符实现奇偶数的判断,C和Java版1

C语言版:

#include <stdio.h>


int fun_isodd(int x){


while(x!=-1){
if(((x>>1)<<1) == x){
return 0;   //是偶数
}
return 1;       //是奇数
}
return 1;       //是奇数
}


void main(){
int m;
printf("请输入一个整数:");
scanf("%d",&m);


int n = fun_isodd(m);
if(n == 1){
printf("%d:是奇数",m);
}else{
printf("%d: 是偶数",m);
}
}

Java中int型范围 -2147483648 到2147483647( 32位的带符号的,无符号的是0-2*2147483648)
Java版:


import java.util.*;


public class IsOdd
{
public static void main(String args[]){
Scanner s = new Scanner(System.in);//从键盘上输入


int m = s.nextInt();//读取一个整数

long time1 = System.currentTimeMillis();
if(oddEvenDiv(m) == 0)
System.out.println(m + ": 是偶数");
else
System.out.println(m + ": 是奇数");
long time2 = System.currentTimeMillis();


System.out.println(time1);
System.out.println(time2);
}


public static int oddEvenMove(int x){ //判断奇数偶数的函数
if(((x>>1)<<1)==x)  //使用移位,如果一个数右移一位,再左移一位(左移时最后一位补0),和原来的数相等,则为偶数
return 0;
else
return 1;
}


public static int oddEvenDiv(int x){//判断奇数偶数的函数
if(x%2 == 0)  //使用普通方法,对整数2取余
return 0;
else 
return 1;
}
}

阅读更多
上一篇java中float和double到底有什么区别?
下一篇WarShall算法实现,C、Java版
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭