zoukankan      html  css  js  c++  java
  • Java解惑之奇数性————《Java解惑》有感+笔记

    当我们要判断一个数是否为奇数时我们经常会写以下代码

       1:  public static boolean isOdd(int i)
       2:  {
       3:      return i%2==1;
       4:  }

    但是当i为负奇数的时候,i%2返回值为-1不是1,所以当i为负数的时候函数的返回值都是false。

    原因在于,Java对取余操作符的定义为

    对所有int数值a和所有非零int数值b,都满足以下恒等式

    (a/b)*b+(a%b)==a

    很明显,a%b取余后的数必须和a一样的符号才能满足以上等式。

    所以,在Java中i%2==1 不等于i%2!=0;

    因此,在java中你可以这样判断一个数是不是奇数,只要判断他不是偶数就可以了

       1:  public static boolean isOdd(int i)
       2:  {
       3:      return (i%2)!=0;
       4:  }

    当然这还有更好的办法,你可以用与符号来完成判断是否为一个偶数或者奇数

       1:  public static boolean isOdd(int i)
       2:  {
       3:      return (i&1)==1;
       4:  }

    原理是奇数用二进制表示最后一位总是1,当和1与操作的时候就剩下最后一位为1了

    偶数也是同样道理,我就不多说了,这种算法比上面取余的算法要快一点(毕竟计算

    机比较喜欢使用逻辑运算的,不信的话可以自己验证一下,我把我的验证代码也贴出来一下),

       1:  public class MainClass
       2:  {
       3:      public static void main(String[] args)
       4:      {
       5:          for (int j = 0; j < 100000000; j++){}//不写这个的话,第二个运行的总会比第一个块,其实就是让它稳定后再测试
       6:          final int time = 1999999999;
       7:  //        Scanner s = new Scanner(System.in);
       8:          long startTime = System.nanoTime();
       9:          for (int i = 0; i < time; i++)
      10:          {
      11:              isOdd(i);
      12:          }
      13:   
      14:          long endTime = System.nanoTime();
      15:   
      16:          System.out.println(endTime - startTime);
      17:          long startTime2 = System.nanoTime();
      18:   
      19:   
      20:          for (int i = 0; i < time; i++)
      21:          {
      22:              isOdd2(i);
      23:          }
      24:          long endTime2 = System.nanoTime();
      25:          System.out.println(endTime2 - startTime2);
      26:      }
      27:   
      28:      public static boolean isOdd(int i)
      29:      {
      30:          return (i & 1) != 0;
      31:      }
      32:   
      33:      public static boolean isOdd2(int i)
      34:      {
      35:          return (1 % 2) != 0;
      36:      }
      37:   
      38:  }

    并且符合计算机的思维所以我推荐使用最后一种的方法。这个问题同样在C++也是会出现的,这里就不多说了

    总结一下

    取余操作遇到负数时要小心符号
  • 相关阅读:
    利用Bootstrap快速搭建个人响应式主页(附演示+源码)
    Socket实现仿QQ聊天(可部署于广域网)附源码(2)-服务器搭建
    Socket实现仿QQ聊天(可部署于广域网)附源码(1)-简介
    开拓思维,如何用编程思想进行三维建模(2)
    开拓思维,如何用编程思想进行三维建模(1)
    浅谈Winform事件的实现以及模拟其事件的实现(附实现源码)
    Winform实现Shp-栅格图形文件的读取与显示(外加shp转WKB格式存入oracle)附源码
    本地MVC项目发布到IIS服务器
    Asp.net mvc4 安装报错处理方法(x80070005 拒绝访)
    MySql 主从复制及主主复制
  • 原文地址:https://www.cnblogs.com/Jabba93/p/2701641.html
Copyright © 2011-2022 走看看