日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

算法杂项~

發布時間:2025/6/17 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 算法杂项~ 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 前言
  • 一、O(logn)算法
    • 1.1、折半/二分查找(binary search)
    • 1.2、求最大公因數
    • 1.3、冪運算
  • 總結


前言

??????隨便列出一些常見的算法。

一、O(logn)算法

??????如果一個算法用常數時間將問題的大小削減為其一部分(一般為其的1/2),那么該算法的時間復雜度為 O(logn)。

1.1、折半/二分查找(binary search)

??????假設對一個已經排好序的 int 數組 array,求某個元素 n 在該數組的下標:

public static int binarySearch(int[] array,int n){int left=0,right=array.length-1,mid;while(left<=right){mid=(left+right)/2;if(array[mid]==n)return mid;else if(array[mid]<n)left=mid+1;elseright=mid-1;}return -1;}

1.2、求最大公因數

??????歐幾里得算法求最大公因數:

public static int gcd(int m,int n){while(n!=0){ //如果 m 小于 n,那么第一次循環會交換 m 和 n 的值。int y=m%n;m=n;n=y;}return m;}

1.3、冪運算

??????代碼如下:

public static int pow(int base,int e){//大致確定結果在 int 范圍內,如果數字很大,可能需要采用別的表示方法來模擬(比如字符串)。if(e==0)return 1;if(e%2==0)return pow(base*base,e/2);elsereturn pow(base*base,e/2)*base;}

??????
??????
??????
??????
??????
??????
??????
??????
??????
??????
??????

??????
??????
??????
??????
??????
??????
??????
??????
??????
??????
??????
??????
??????
??????
??????

??????
??????
??????
??????
??????
??????
??????
??????
??????
??????
??????
??????
??????
??????
??????


總結

??????未完~

《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的算法杂项~的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。