亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

多線程加速快排(java)

2019-11-06 06:11:44
字體:
來源:轉載
供稿:網友

1.快排的過程: a)設置兩個變量,分別指向數組的首尾,選擇一個標志元素(一般是第一個元素) b)從后向前找比標志元素小的值,從前向后找比標志元素大的值,將小的移到低端,將大的移到高端,更新標志元素的位置。 c)只要首尾兩個指針不相遇,就循環進行 這樣一次循環的結果是標志元素左邊的都比它小,右邊的都比它大 d)將被標志元素分開的兩個數組再遞歸(a,b,c) 2.快排代碼

class quicksort{ public void sort(int left,int right,int str[]) { int i,j,pos; if(left>=right) { return; } i=left; j=right; pos=str[i]; while(i<j) { while(i<j && pos<=str[j]) { j--; } if(i<j) { str[i]=str[j]; } while(i<j && pos>=str[i]) { i++; } if(i<j) { str[j] = str[i]; } str[i]=pos; sort(left,i-1,str); sort(i+1,right,str); } }}

3.多線程加速快排 a,b,c三步可以看成是一個小任務,將整個任務分成若干個小任務,分而治之。因為每個小任務之間有聯系,不能跟求值的多線程一樣,只要有個共享數據,將值相加。這里用Callable 接口(Callable 接口類似于 Runnable),該接口可以帶返回值。

1)返回值的結構為

class temp{ PRivate int left=0; private int right=0; private int middle=0; public temp(int left, int right, int middle) { this.left = left; this.right = right; this.middle = middle; } public int getLeft() { return left; } public int getRight() { return right; } public int getMiddle() { return middle; } public boolean cmpLeftMiddle() { return left<middle-1; } public boolean cmpMiddleRight() { return middle+1<right; }}

2)實現Callable 接口

class myThread implements Callable<temp>{ private int left; private int right; private int middle; private int str[]; public myThread(int left, int right, int str[]) { this.left=left; this.right=right; this.str=str; } public temp call() { onesort(); return new temp(left,right,middle); } public void onesort() { int i,j,pos; if(left>=right) { return; } i=left; j=right; pos=str[i]; while(i<j) { while(i<j && pos<=str[j]) { j--; } if(i<j) { str[i]=str[j]; } while(i<j && pos>=str[i]) { i++; } if(i<j) { str[j] = str[i]; } str[i]=pos; } middle = i; }}

4.普通快排與多線程加速快排的對比 測試類:

public class Qsort { //創建線程池 ExecutorService pool = Executors.newFixedThreadPool(6); private int[] str=null; public Qsort(int str[]) { this.str = str; sort(0,str.length-1); } //分治 public void sort(int begin, int end) { //Future用來接收返回值 Future<temp> future = pool.submit(new myThread(begin, end, str)); try { if(future.get().cmpLeftMiddle()) { sort(future.get().getLeft(),future.get().getMiddle()-1); } if(future.get().cmpMiddleRight()) { sort(future.get().getMiddle()+1,future.get().getRight()); } } catch (InterruptedException e) { // TODO 自動生成的 catch 塊 e.printStackTrace(); } catch (ExecutionException e) { // TODO 自動生成的 catch 塊 e.printStackTrace(); } } public static void main(String[] args) { int a[] = new int[1024]; for(int i=0;i<1024; i++) { a[i] = (int)(Math.random()*100); System.out.print(a[i]+" "); } System.out.println(); long star = System.currentTimeMillis(); new Qsort(a); // new quicksort().sort(0, a.length-1, a); long end = System.currentTimeMillis(); for(int i=0; i<a.length; i++) { System.out.print(a[i] + " "); } System.out.println(); System.out.println(end-star); }}

1)未加速的快排 這里寫圖片描述

2)加速的快排 這里寫圖片描述


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久亚洲国产精品成人av秋霞| 91久久国产精品91久久性色| 日韩毛片在线看| 日韩av三级在线观看| 日韩欧美成人区| 亚洲人成伊人成综合网久久久| 91精品国产91久久| 午夜精品一区二区三区在线视频| 日韩中文字幕在线免费观看| 青青久久av北条麻妃海外网| 日本成人在线视频网址| 亚洲一区二区国产| 亚洲精品ady| 日韩在线视频观看| 国产亚洲在线播放| 国产精品v片在线观看不卡| 成人h片在线播放免费网站| 在线观看日韩www视频免费| 久久精品在线播放| 国产精品久久久| 日韩精品福利网站| 成人免费高清完整版在线观看| 91极品视频在线| 91精品国产91久久| 国产精品吴梦梦| 国产精品尤物福利片在线观看| 宅男66日本亚洲欧美视频| 亚洲人成电影网站色| 亚洲欧洲xxxx| 午夜精品久久久久久久久久久久| 国产亚洲精品久久久久久777| 亚洲激情小视频| 51精品国产黑色丝袜高跟鞋| 欧美日韩福利在线观看| 成人高h视频在线| 国产精品美女免费视频| 97国产成人精品视频| 俺去亚洲欧洲欧美日韩| 日韩欧美福利视频| 亚洲免费伊人电影在线观看av| 国产精品ⅴa在线观看h| 国语自产精品视频在线看| 成人免费看黄网站| 欧美视频专区一二在线观看| 成人激情黄色网| 亚洲伊人成综合成人网| 国产精品日日摸夜夜添夜夜av| 91精品国产91久久久久久吃药| 中文字幕一精品亚洲无线一区| 91免费国产网站| 57pao国产精品一区| 亚洲国产欧美一区二区丝袜黑人| 中文字幕日韩在线视频| 欧美一级视频免费在线观看| 久久精品91久久久久久再现| 亚洲香蕉av在线一区二区三区| 欧美激情精品久久久久久变态| 成人乱人伦精品视频在线观看| 亚洲国产精品久久91精品| 97视频在线观看视频免费视频| 成人h视频在线观看播放| 亚洲天堂第一页| 一区二区日韩精品| 久久天天躁狠狠躁老女人| 欧美一级电影在线| 久久久av亚洲男天堂| 欧美成人高清视频| 久久久久久国产精品三级玉女聊斋| 91精品免费久久久久久久久| 日本伊人精品一区二区三区介绍| 久久99国产精品自在自在app| 久久精品成人欧美大片| 欧美视频中文字幕在线| 国内精品在线一区| 中文字幕精品视频| 深夜福利日韩在线看| 日韩欧美国产骚| 91久久精品在线| 欧美日韩另类在线| 91亚洲国产成人精品性色| 久久九九亚洲综合| 精品无人国产偷自产在线| 国产丝袜一区二区| 国语对白做受69| 亚洲精品wwww| 国产美女直播视频一区| 欧美性猛交xxxx免费看漫画| 日本精品久久中文字幕佐佐木| 日韩在线免费视频观看| 国产精品aaaa| 亚洲男人天堂网站| 国产一区二区三区直播精品电影| 日韩精品日韩在线观看| 欧美日韩在线免费| 国产精品狠色婷| 超碰日本道色综合久久综合| 亚洲毛茸茸少妇高潮呻吟| 国产成人涩涩涩视频在线观看| 亚洲午夜精品久久久久久性色| 国产精品高潮呻吟视频| 久久天堂av综合合色| 国产精品夜色7777狼人| 国产精品草莓在线免费观看| 日韩精品丝袜在线| 精品国偷自产在线视频| 69久久夜色精品国产69| 久久久久女教师免费一区| 91chinesevideo永久地址| 成人免费看黄网站| 欧美一级淫片aaaaaaa视频| 91亚洲精品在线观看| 亚洲男人天堂视频| 精品久久久久久久久中文字幕| 国产精品一区久久| 日韩中文字幕视频| 国产精品视频免费在线观看| 国产精品久久久久9999| 久久精品久久久久电影| 日韩精品中文字幕视频在线| 97在线视频免费| 国产亚洲视频在线观看| 国产精品久久在线观看| 国产精品久久久久久中文字| 亚洲午夜精品久久久久久久久久久久| 一区二区三区动漫| 国产一区二区欧美日韩| 国产福利精品av综合导导航| 国产香蕉一区二区三区在线视频| 欧美日韩日本国产| 丰满岳妇乱一区二区三区| 中文国产成人精品久久一| 日韩在线资源网| 91伊人影院在线播放| 亚洲第一视频在线观看| 日韩av电影中文字幕| 欧美精品午夜视频| 81精品国产乱码久久久久久| 成人在线国产精品| 亚洲网在线观看| 欧美成人小视频| 欧美性生活大片免费观看网址| 九九热视频这里只有精品| 91wwwcom在线观看| 一本一本久久a久久精品牛牛影视| 国产在线999| 国产精品一区久久久| 日本免费久久高清视频| 欧美美最猛性xxxxxx| 另类专区欧美制服同性| 97久久精品在线| 亚洲qvod图片区电影| 国产精品成人观看视频国产奇米| 亚洲自拍偷拍一区| 国产97在线观看| 欧美做受高潮电影o| 日韩av中文字幕在线免费观看| 久久精品国产精品亚洲| 久久久精品在线观看| 欧美成人sm免费视频| 国产精品视频一| 97在线日本国产| 亚洲女人被黑人巨大进入| 91网在线免费观看| 怡红院精品视频|