zoukankan      html  css  js  c++  java
  • 快速判断是否2的N次方

    今天看到别人在讨论如何快速判断2的N次方,自己也思考了下。这里汇总一下。

    一、最快速的方法:

    (number & number - 1== 0

     原因:因为2的N次方换算是二进制为10……0这样的形式(0除外)。与上自己-1的位数,这们得到结果为0。例如。8的二进制为1000;8-1=7,7的二进制为111。两者相与的结果为0。计算如下。

      1000
    & 0111
    -------
      0000

     代码:

    //从textbox中取到数字
    long number = long.Parse(txbNumber.Text);

            
    /// <summary>
            
    /// 使用“与”
            
    /// </summary>
            private void UseAndMethod()
            {
                
    if (number==1)
                {
                    Response.Write(
    "不是");
                    
    return;
                }
                
    string result = (number & number - 1).ToString();
                
    if ((number & number - 1== 0)
                {
                    Response.Write(
    "");
                }
                
    else
                {
                    Response.Write(
    "不是");
                }
            }

    二、使用数学函数(没有第一个方法好)

    //从textbox中取到数字
    long number = long.Parse(txbNumber.Text);

            
    /// <summary>
            
    /// 使用Math.Log方法计算
            
    /// </summary>
            private void UseMathLog()
            {
                DateTime dtStart 
    = DateTime.Now;
                
    double power = Math.Log(number, 2);
                
    long result = 0;
                
    if (Int64.TryParse(power.ToString(), out result))
                {
                    DateTime dtEnd 
    = DateTime.Now;
                    Response.Write(number 
    + "是2的" + power + "次方,花费时间为" + DateDiff(dtEnd, dtStart));
                }
                
    else
                {
                    DateTime dtEnd 
    = DateTime.Now;
                    Response.Write(number 
    + "不是2的n次方," + "近接近的幂为:" + power + ",花费时间为" + DateDiff(dtEnd, dtStart));
                }
            }
            //计算时间
            private string DateDiff(DateTime DateTimeEnd, DateTime DateTimeStart)
            {
                
    string dateDiff = null;
                TimeSpan ts1 
    = new TimeSpan(DateTimeEnd.Ticks);
                TimeSpan ts2 
    = new TimeSpan(DateTimeStart.Ticks);
                TimeSpan ts 
    = ts1.Subtract(ts2).Duration();
                dateDiff 
    = ts.TotalMilliseconds.ToString() + "毫秒";
                
    return dateDiff;
            }

        还有其它的一些算法。这里只列出两个。

  • 相关阅读:
    分类与监督学习,朴素贝叶斯分类算法
    K-means算法应用:图片压缩
    聚类--K均值算法:自主实现与sklearn.cluster.KMeans调用
    numpy统计分布显示
    10.11作业numpy数据集练习
    9.29作业
    CAGradientlayer设置视图背景的渐变效果
    dyld: Library not loaded: @rpath/libswiftCore.dylib
    解读NSString之性能分析
    iOS UIButton超出父视图无法点击解决方法
  • 原文地址:https://www.cnblogs.com/scottckt/p/1970682.html
Copyright © 2011-2022 走看看