程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA編程入門知識 >> java 使用簡單的demo實例告訴你優化算法的強大

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

編輯:JAVA編程入門知識

這裡的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 href="http://zhidao.baidu.com/question/411055258.html">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 href="http://zhidao.baidu.com/question/411055258.html">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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved