国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

java 使用簡單的demo實例告訴你優化算法的強大

2019-11-26 16:09:27
字體:
來源:轉載
供稿:網友

這里的demo是一個累加算法,如1,2,3,4.....n

即:sum = 1+2+3+4......+n;

我們可以這樣做:

復制代碼 代碼如下:

/**
      * 循環實現累加方法
      * @param value
      * @return
      */
     private static long cycle(long value) {
         long sum = 0;

         for (long i = 1,v = value; i <= v; i++) {
             sum += i;
         }
         return sum;
     }

另一種方法(高斯方法):
復制代碼 代碼如下:

/**
      * 高斯方法:<code>(n+1)*n/2</code><br>
      * you can read more from <a >Here</a>
      * @param value
      * @return
      */
     private static long gaosi(long value) {
         long sum = 0;
         sum = (value + 1) * value / 2;
         return sum;
     }

我們可以寫一個demo來測試他們的差別:
復制代碼 代碼如下:

/**
  *
  */
 package com.b510.arithmetic;

 /**
  * 累加算法實現<br>
  *
  * @date 2013-4-16
  * @author hongten
  *
  */
 public class AddArithmetic {

     /**
      * 循環實現累加方法
      * @param value
      * @return
      */
     private static long cycle(long value) {
         long sum = 0;

         for (long i = 1,v = value; i <= v; i++) {
             sum += i;
         }
         return sum;
     }

     /**
      * 高斯方法:<code>(n+1)*n/2</code><br>
      * you can read more from <a >Here</a>
      * @param value
      * @return
      */
     private static long gaosi(long value) {
         long sum = 0;
         sum = (value + 1) * value / 2;
         return sum;
     }

     public static void main(String[] args) {
         //清理一下內存,但不一定會執行
         System.gc();
         // you should change value,then get the different results
         long value = 10000000;
         long sum = 0;
         long start = System.currentTimeMillis();
         sum = cycle(value);
         long end = System.currentTimeMillis();
         System.out.println("使用循環累加方法從[1]累加到["+value+"]用時 : ["+(end - start) + "]ms,結果:"+ sum);
         //清理一下內存,但不一定會執行
         System.gc();
         start = System.currentTimeMillis();
         sum = gaosi(value);
         end = System.currentTimeMillis();
         System.out.println("使用高斯方法從[1]累加到["+value+"]用時 : ["+(end - start) + "]ms,結果:"+ sum);

     }

 }

你可以改變main方法中的value的值,來測試他們所消耗的系統時間....

當然不同配置的機器運行結果是不一樣的...

我機器運行情況:

復制代碼 代碼如下:

使用循環累加方法從[1]累加到[10000000]用時 : [24]ms,結果:50000005000000
使用高斯方法從[1]累加到[10000000]用時 : [0]ms,結果:50000005000000

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 都安| 遵化市| 通化市| 永寿县| 当雄县| 托克逊县| 新化县| 谷城县| 甘南县| 海淀区| 杭锦旗| 方山县| 文登市| 克东县| 出国| 伊吾县| 东乡族自治县| 柯坪县| 山东省| 布尔津县| 永和县| 黔东| 黄浦区| 米脂县| 秀山| 景谷| 金塔县| 开鲁县| 手游| 赤水市| 扶绥县| 确山县| 渝中区| 柳林县| 富锦市| 蒙山县| 克山县| 兴和县| 兴和县| 平谷区| 同仁县|