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;
            }

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

  • 相关阅读:
    linux在线书籍
    数据库使用记录(二)
    python读取配置文件报keyerror文件路径不正确导致的错误
    pycharm全局搜索快捷键无反应
    UVA 11054 Wine trading in Gergovia (Gergovia 的酒交易)(贪心+模拟)
    UVA 12107 Digit Puzzle(数字谜)(IDA*)
    UVA 12113 Overlapping Squares(重叠的正方形)
    UVA 10384 The Wall Pusher(推门游戏)(IDA*)
    UVA 11277 Cyclic Polygons(二分)
    【洛谷P2922】秘密消息【Trie】
  • 原文地址:https://www.cnblogs.com/scottckt/p/1970682.html
Copyright © 2011-2022 走看看