久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > java中常用的算法總結(jié)

java中常用的算法總結(jié)

來(lái)源:千鋒教育
發(fā)布人:wjy
時(shí)間: 2022-04-20 11:31:00 1650425460

  程序員進(jìn)行編程的過(guò)程中肯定少不了對(duì)于數(shù)據(jù)的處理,那么此時(shí)了解Java算法就非常重要,Java算法有很多,今天千鋒小編針對(duì)Java中常用的算法做了一期整理,下面就簡(jiǎn)單的介紹一下程序員常用的一些Java算法。

     java中常用的算法

  一、排序

  1.1 排序概述

  排序(sorting)的功能是將一個(gè)數(shù)據(jù)元素的任意序列,重新排列成一個(gè)按關(guān)鍵字有序的序列。

  內(nèi)部排序和外部排序:一類(lèi)是整個(gè)排序過(guò)程在內(nèi)存儲(chǔ)器中進(jìn)行,稱(chēng)為內(nèi)部排序;另一類(lèi)是由于待排序元素?cái)?shù)量太大,使得內(nèi)存儲(chǔ)器無(wú)法容納全部數(shù)據(jù),排序需要借助外部存儲(chǔ)設(shè)備才能完成,這類(lèi)排序稱(chēng)為外部排序。

  比較排序和非比較排序

  大部分排序都是需要通過(guò)比較首先來(lái)判斷大小,作為排序的依據(jù)的。

  但是也有例外,比如計(jì)數(shù)排序、基數(shù)排序不需要進(jìn)行比較。效率可以更高,但同時(shí)也會(huì)有一些限制條件,也可能需要更多的空間。

  冒泡排序、選擇排序、直接插入排序是最基本的三種排序,效率低但是算法簡(jiǎn)單。排序的學(xué)習(xí)一般從這三種排序算法著手。

  1.2冒泡排序

  冒泡排序的算法

  1) 整個(gè)數(shù)列分成兩部分:前面是無(wú)序數(shù)列,后面是有序數(shù)列

  2) 初始狀態(tài)下,整個(gè)數(shù)列都是無(wú)序的,有序數(shù)列是空

  3) 如果一個(gè)數(shù)列有n個(gè)元素,則至多需要n-1趟循環(huán)才能保證數(shù)列有序

  4) 每一趟循環(huán)可以讓無(wú)序數(shù)列中最大數(shù)排到最后,(也就是說(shuō)有序數(shù)列的元素個(gè)數(shù)增加1)

  5) 每一趟循環(huán)都從數(shù)列的第一個(gè)元素開(kāi)始進(jìn)行比較,依次比較相鄰的兩個(gè)元素,比較到無(wú)序數(shù)列的末尾即可(而不是數(shù)列的末尾)

  6) 如果前一個(gè)大于后一個(gè),交換

  1.3 選擇排序

  選擇排序的算法

  1) 整個(gè)數(shù)列分成兩部分:前面是有序數(shù)列,后面是無(wú)序數(shù)列

  2) 初始狀態(tài)下,整個(gè)數(shù)列都是無(wú)序的,有序數(shù)列是空

  3) 一共n個(gè)數(shù),需要n-1趟循環(huán)(一趟都不能少)

  4) 每比較完一趟,有序數(shù)列數(shù)量+1,無(wú)序數(shù)列數(shù)量-1

  5) 每趟先假設(shè)無(wú)序數(shù)列的第1個(gè)元素(整個(gè)數(shù)列的第i個(gè)元素)是最小的,讓當(dāng)前最小數(shù),從第i+1個(gè)元素開(kāi)始比較,一直比較到最后一個(gè)元素。如果發(fā)現(xiàn)更小的數(shù),就假設(shè)當(dāng)前數(shù)是最小數(shù)。

  6) 一趟比較完后,將發(fā)現(xiàn)最小數(shù)和無(wú)序數(shù)列的第一個(gè)數(shù)交換(如果最小數(shù)不是無(wú)序數(shù)列的第一個(gè)數(shù))

  二、遞歸和折半查找

  2.1 遞歸

  遞歸(recursion)是一種常見(jiàn)的解決問(wèn)題的方法,即把問(wèn)題逐漸簡(jiǎn)單化。遞歸的基本思想就是“自己調(diào)用自己”,一個(gè)使用遞歸技術(shù)的方法將會(huì)直接或者間接的調(diào)用自己。利用遞歸可以用簡(jiǎn)單的程序來(lái)解決一些復(fù)雜的問(wèn)題。比如:斐波那契數(shù)列的計(jì)算、漢諾塔、快速排序等問(wèn)題。

  遞歸問(wèn)題的特點(diǎn):一個(gè)問(wèn)題可被分解為若干層簡(jiǎn)單的子問(wèn)題;子問(wèn)題和其上層問(wèn)題的解決方案一致;外層問(wèn)題的解決依賴(lài)于子問(wèn)題的解決。

    與此同時(shí),遞歸有著思路自然、程序簡(jiǎn)單的優(yōu)點(diǎn),自然也有缺點(diǎn),遞歸調(diào)用會(huì)占用大量的系統(tǒng)堆棧,內(nèi)存耗用多,在遞歸調(diào)用層次多時(shí)速度要比循環(huán)慢的多。

  2.2 折半查找

  折半查找又稱(chēng)為二分查找,這種查找方法需要待查的查找表滿(mǎn)足兩個(gè)條件:

  首先,查找表必須使用順序存儲(chǔ)結(jié)構(gòu);

  其次,查找表必須按關(guān)鍵字大小有序排列。

    上面就是java中常用的算法的一個(gè)簡(jiǎn)單的介紹和總結(jié)。希望這篇對(duì)Java語(yǔ)言經(jīng)典算法的介紹能夠幫助大家。如果你對(duì)Java培訓(xùn)有興趣,歡迎隨時(shí)咨詢(xún)千鋒教育!

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專(zhuān)屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
今日頭條展現(xiàn)量是什么?今日頭條展現(xiàn)量規(guī)則分析

目前頭條用戶(hù)會(huì)發(fā)現(xiàn)微頭條和問(wèn)答新增了“展現(xiàn)量”指標(biāo)。那么這個(gè)今日頭條展現(xiàn)量是什么意思呢?如何提高呢?下面千鋒教育小編就和大家說(shuō)...詳情>>

2023-09-19 09:15:47
我想直播帶貨去哪里找貨源一件代發(fā)

現(xiàn)在直播帶貨是一個(gè)非?;鸬男袠I(yè),越來(lái)越多的人進(jìn)入到這個(gè)圈子,但是,認(rèn)真地說(shuō),直播帶貨能不能賺到錢(qián)還是要看自己。雖然這一行業(yè)火,收入高,...詳情>>

2023-09-19 08:41:02
入駐短視頻mcn需要多少錢(qián)?有哪些費(fèi)用?

眾所周知,現(xiàn)在短視頻成了很多人的自媒體創(chuàng)業(yè)道路之一,越來(lái)越多人喜歡在網(wǎng)上消遣時(shí)間,購(gòu)物等。也有很多優(yōu)秀的博主去做出很多新的內(nèi)容,那么入...詳情>>

2023-09-19 08:12:47
短視頻帶貨應(yīng)該注冊(cè)什么公司?需要什么資料?

短視頻大家應(yīng)該都非常熟悉,現(xiàn)在很多人都喜歡在閑暇的時(shí)候刷短視頻,短視頻平臺(tái)也開(kāi)始了直播帶貨,商家也都開(kāi)始創(chuàng)業(yè)了,那么短視頻帶貨需要營(yíng)業(yè)...詳情>>

2023-09-19 08:09:31
怎樣投抖加不花錢(qián)?別人能看出來(lái)嗎?

抖音一些視頻為了獲取更多點(diǎn)擊,一些博主機(jī)會(huì)投抖加。其實(shí)抖加的投放沒(méi)有絕對(duì)正確的方法,而不同賬號(hào)和視頻投放的策略都是不一樣的,不過(guò)一般情...詳情>>

2023-09-19 08:00:10
開(kāi)班信息
北京校區(qū)
  • 北京校區(qū)
  • 大連校區(qū)
  • 廣州校區(qū)
  • 成都校區(qū)
  • 杭州校區(qū)
  • 長(zhǎng)沙校區(qū)
  • 合肥校區(qū)
  • 南京校區(qū)
  • 上海校區(qū)
  • 深圳校區(qū)
  • 武漢校區(qū)
  • 鄭州校區(qū)
  • 西安校區(qū)
  • 青島校區(qū)
  • 重慶校區(qū)
  • 太原校區(qū)
  • 沈陽(yáng)校區(qū)
  • 南昌校區(qū)
  • 哈爾濱校區(qū)