求立方根演算法--個人對立方根演算法的窮舉和優化

来源:http://www.cnblogs.com/gfuzan/archive/2017/08/09/7323341.html
-Advertisement-
Play Games

在hpe實訓中心學習,遇到了求立方根的題目,在此做一下演算法筆記, 分析過程: 數n的立方根就是n=i*i**i;所以我們會優先想到一下方法. 可以看出此方法的求解精度為0.001;且當輸入數據過大時效率堪憂,所以就有了以下優化 此方法可以快速求得立方根,輸入數值n不太大時使用,當n太大在逼近過程中i ...


在hpe實訓中心學習,遇到了求立方根的題目,在此做一下演算法筆記,

分析過程:

數n的立方根就是n=i*i**i;所以我們會優先想到一下方法.

    static double g32(double n){ //簡易版
        double i = 0, k = 0.0005f;
        if (n < 0) {    //輸入負數判斷
            k /= -1;
        }
        do{
            i+=k;
        }while(abs(i*i*i)<abs(n)); //abs為自己寫的求絕對值方法
        return i;
    }

可以看出此方法的求解精度為0.001;且當輸入數據過大時效率堪憂,所以就有了以下優化

    static double g33(double n){    //優化2
        double i = 0, k = 5f;
        if (n < 0) {
            k /= -1;
        }for (int t = 0; t < 15; t++) {//精度到小數點後15位
            do {
                i += k;  //開始時每次加5快速逼近正確值
            } while (abs(i * i * i) < abs(n));  //當i^3>=n時退出
            i-=k;k /= 9.2;  //i還原到退出前的值,k縮小,進入下一次逼近
        } 
        return i;
    }

此方法可以快速求得立方根,輸入數值n不太大時使用,當n太大在逼近過程中i^3與(i+k)^3差距太大,迴圈次數劇增,進入死迴圈狀態.在我電腦上當n=9999999999 (10個9)時就會進入死迴圈

所以想到一種解決方法,設置一迴圈次數計數器w,使k值隨迴圈次數增加而增加,在一定程度上解決死迴圈問題.下麵是代碼

    static double g34(double n){    //最終優化
        double i = 0, k = 5f;
        if (n < 0) {
            k /= -1;
        }
        int w=0;
        for (int t = 0; t < 15; t++) {
            do {
                i += k;
                k=k+w*k/50000;
                w++;  //迴圈計數器
            } while (abs(i * i * i) < abs(n));
            i-=k;k /= 9.5;
        }
        System.out.println(w);
        return i;
    }

更改後n等於20個9也不會死迴圈.

最後附上所有程式代碼.

package com.gfuzan.test;

import java.util.Scanner;

public class Test {

    /**
     * 開發: GFuZan
     * 時間: 2017.08.08
     * 功能: 立方根
     */
    public static void main(String[] args) {
        System.out.print("請輸入一個數: ");
        Scanner sc = new Scanner(System.in);
        double n = sc.nextDouble();
        sc.close();
        System.out.println("Math:    \t"+ Math.pow(n, 1.0/3));
        System.out.println("My簡易版:  \t"+g32(n)); 
        System.out.println("My優化2:  \t"+g33(n)); 
        System.out.println("My最終優化:\t"+g34(n)); 
        
    }
    
    static double g32(double n){ //簡易版
        double i = 0, k = 0.0005f;
        if (n < 0) {
            k /= -1;
        }
        do{
            i+=k;
        }while(abs(i*i*i)<abs(n));
        return i;
    }
    static double g34(double n){    //最終優化
        double i = 0, k = 5f;
        if (n < 0) {
            k /= -1;
        }
        int w=0;
        for (int t = 0; t < 15; t++) {
            do {
                i += k;
                k=k+w*k/50000;
                w++;
            } while (abs(i * i * i) < abs(n));
            i-=k;k /= 9.5;
        }
        return i;
    }
    static double g33(double n){    //優化2
        double i = 0, k = 5f;
        if (n < 0) {
            k /= -1;
        }
        for (int t = 0; t < 15; t++) {
            do {
                i += k;
            } while (abs(i * i * i) < abs(n));
            i-=k;k /= 9.2;
        }
        return i;
    }
    static double abs(double f) {
        if (f < 0) {
            return 0 - f;
        }
        return f;
    }
}

運行結果

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 第一個shell腳本 #! 是一個約定的標記,它告訴系統這個腳本需要什麼解釋器來執行,即使用哪一種 Shell 將上面的代碼保存為 test.sh,並 cd 到相應目錄 Shell 變數 除了顯式地直接賦值,還可以用語句給變數賦值,如: 以上語句將 /etc 下目錄的文件名迴圈出來 使用一個定義過的 ...
  • 上下文Context類中的base構造器的幾個方法重置(1、無參 2、database name 3 、 連接字元串) 無參:如果基類base方法中無參,code first將會以 :{Namespace}.{Context class name} 為名字創建一個服務 1 public class ...
  • IdentityServer4 是一個提供 認證服務,單點登錄/登出(SSO),API訪問控制,聯合認證通道的可定製、免費商業支持的框架。 ...
  • 1、根據自己的理解,Code First :通過實體類和相關配置生成對應的資料庫,實現實體和資料庫的映射關係,或通過實體類和相關配置與已經生成的實體與已經存在的資料庫搭建映射關係 例: 實體類:StudentInfo、ClassInfo 1 public class ClassInfo 2 { 3 ...
  • 微服務現在已經是各種互聯網應用首選的雲架構組件,無論是 BAT 還是 滴滴、美團 ,微服務都是重要的一環。 相對於微服務,傳統應用架構有以下缺點: 1. 業務代碼混雜,團隊成員職責邊界不清,團隊協作體驗不佳,開發效率低下。 傳統應用架構中,各個業務模塊代碼都存在於同一個應用當中,各個業務模塊之間交互 ...
  • IdentityServer4 是一個提供 認證服務,單點登錄/登出(SSO),API訪問控制,聯合認證通道的可定製、免費商業支持的框架。 ...
  • 第 6 章:擴展性設計 6.1 擴展機制 考慮用不包含任何虛成員或受保護的成員的非密封類來為框架提供擴展性。這種方法所提供的擴展性廣受用戶歡迎,而且它的開銷也不高。 考慮將受保護的成員用於高級的定製方案。 要在對安全性、文檔及相容性進行分析時,把非密封類中受保護的成員當做公有成員那樣來對待。 考慮使 ...
  • 14.1 字元 三種數值類型與 Char 實例的相互轉換: 14.2 System.String類型 14.2.1 構造字元串 14.2.2 字元串是不可變的 14.2.3 比較字元串 出於編程的目的而比較字元串時,應該總是使用 StringComparison.Ordinal 或者 StringC ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...