#include <stdio.h>
#include<stdafx.h>
#include<iostream>
#include <stdlib.h>
#include <time.h>
#include "omp.h"
using namespace std;
//int count=0;
void swap(int &a, int &b)//
{
int tmp;
tmp = a;
a = b;
b = tmp;
}
void quicksort(int *A,int l, int u)
{
int i,m,k;
if (l >= u) return;
m = l;
for (i = l+1; i <= u; i++)
if (A[i] < A[l])/*无论是选第一个元素作为pivot还是最后一个作为pivot,假如我们想得到的是从小到大的序列。那么最坏的输入
//情况就是从大到小的;假设我们想得到从大到小的序列,那个最坏的输入情况就是从小到大的序列*/
swap(A[++m], A[i]);
swap(A[l], A[m]);
quicksort(A,l, m-1);
quicksort(A,m+1, u);
}
void main(int argc, char *argv)
{
omp_set_num_threads(2);//----------------设置线程数为2,由于是双核的CPU
int k=0,i=0;
int m=0,n=0;
double cost=0;
int len=10000;
int short_len=len/2;
int B[10000],C[10000],D[5000],E[5000];//--------将B[]分为两个小的数组,并行的对他们调用高速排序算法
#pragma omp parallel default(none) shared(B,C,len) private(i)//---这个for循环是并行的
{
int j=50000;
#pragma omp for
for(i=0;i<len;i++)
{
B[i]=j--;
C[i]=j--;
//初始化B[],C[]数组
}
}
clock_t begin = clock();//----------------计时開始点
#pragma omp parallel default(none) shared(B,D,E,short_len) private(i)//---这个for循环是并行的
{
#pragma omp for
for(i=0;i<short_len;i++)//---这个for循环是并行的
{
D[i]=B[i];//将B[]的前5000个数放入D[]
E[i]=B[i+5000];//将B[]的后5000个数放入E[]
}
}
#pragma omp parallel default(none) shared(E,D,short_len) //private(i)------高速排序的并行region
{
#pragma omp parallel sections
{
#pragma omp section
quicksort(D, 0, short_len-1);//对D[]排序
#pragma omp section
quicksort(E, 0, short_len-1);//对E[]排序
}
}
for(;k<len;k++)//----------将D[]和E[]进行归并排序放入B[]里面
{
if(m<short_len && n<short_len)
{
if(D[n]<=E[m])
{
B[k] = D[n];
n++;
}
else
{
B[k]=E[m];
m++;
}
}
if(m==short_len || n==short_len)
{
if(m==short_len)
B[k]=E[m];
else
B[k]=D[n-1];
k+=1;
break;
}
}
if(/*m==short_len &&*/ n<short_len)
{
int tem=short_len-n;
for(int p=0;p<tem;p++)
{
B[k]=D[n];
n++;
k++;
}
}
else if(/*n==short_len &&*/ m<short_len)
{
int tem=short_len-m;
for(int q=0;q<tem;q++)
{
B[k]=E[m];
m++;
k++;
}
}//----------------------------归并算法结束
clock_t end = clock();//----------------计时结束点
cost = (double)(end - begin);
cout<<"并行时间"<<cost<<endl;
//串行開始
begin=clock();
quicksort(C, 0, len-1);
end = clock();
cost = (double)(end - begin);
cout<<"串行时间"<<cost<<endl;
system("pause");
}

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvY2hyaXN0cHJpbmNlMDA3/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

OpenMp高速分拣的更多相关文章

  1. 六白话经典算法系列 高速分拣 高速GET

     高速分拣,因为相同的排序效率O(N*logN)几个订购流程更高效,因此,经常使用,再加上高速分拣思想----分而治之的方法也是非常有用的,如此多的软件公司书面采访.它包含了腾讯,微软等知名IT企业宁 ...

  2. 七内部排序算法汇总(插入排序、Shell排序、冒泡排序、请选择类别、、高速分拣合并排序、堆排序)

    写在前面: 排序是计算机程序设计中的一种重要操作,它的功能是将一个数据元素的随意序列,又一次排列成一个按keyword有序的序列.因此排序掌握各种排序算法很重要. 对以下介绍的各个排序,我们假定全部排 ...

  3. 算法---高速分拣(quick sort)

    在前面的排序中所描述的算法.最快的排序算法是归并排序,但是有一个缺陷合并排序排序过程的需求O(N)额外的空间.本文介绍了高速的排序算法到位排序算法,所需的复杂性的额外空间O(1). 算法介绍:高速排序 ...

  4. C面试题

    1.sizeof()和strlen()使用? 答案: 1.从功能定义,strlen功能,要查找字符串的长度,sizeof功能是用来寻找指定的变量或变量类型的存储器占用 尺寸: 2.sizeof是运算符 ...

  5. docker4dotnet #4 使用Azure云存储构建高速 Docker registry

    使用Docker来构建应用程序最常见的操作就是 docker run 或者 docker pull了,但是由于众所周知的原因,在国内想要高速稳定的获取docker hub上面的资源并不是件容易的事情, ...

  6. 应用OpenMP的一个简单的设计模式

    小喵的唠叨话:最近很久没写博客了,一是因为之前写的LSoftmax后馈一直没有成功,所以在等作者的源码.二是最近没什么想写的东西.前两天,在预处理图片的时候,发现处理200w张图片,跑了一晚上也才处理 ...

  7. IT这一行,如可高速下载国外资源之迅雷设置免费SSH代理下载国外资源

    本文转自SUN'S BLOG 原文地址:IT这一行,如可高速下载国外资源之迅雷 我们这些做IT这一行的人,经常,下载一些国外的一些资源,可是让人蛋碎的是,往往这些资源下载都慢的像蜗牛,真的让人无法忍受 ...

  8. openmp 的使用

    http://blog.csdn.net/gengshenghong/article/details/7003110 说明:这部分内容比较基础,主要是分析几个容易混淆的OpenMP函数,加以理解. ( ...

  9. SNMP高速扫描器braa

    SNMP高速扫描器braa   SNMP(Simple Network Monitoring Protocol,简单网络管理协议)是网络设备管理标准协议.为了便于设备管理,现在联入网络的智能设备都支持 ...

随机推荐

  1. jar包生制作几种方法,jar包导出三种方法:eclipse导出、jar命令、FatJar插件

    Eclipse将引用了第三方jar包的Java项目打包成jar文件的两种方法 方案一:用Eclipse自带的Export功能 步骤1:准备主清单文件 “MANIFEST.MF”, 由于是打包引用了第三 ...

  2. android中Logcat的深层理解

    Android的开发也能够归类为嵌入式设备的开发.即便不是嵌入式开发,依旧要注意对内存和处理的使用.养成一个好的习惯对自己的帮助是非常大的. 在Log的源代码中能够看到这种凝视: The order ...

  3. Tengine中的proxy_upstream_tries

    upsream xxx { server 192.168.100.100; server 192.168.100.101; server 192.168.100.102; } server { loc ...

  4. Swift - 类的计算属性(使用get和set来间接获取/改变其他属性的值)

    1,Swift中类可以使用计算属性,即使用get和set来间接获取/改变其他属性的值,代码如下 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 class Calc ...

  5. Linux下select, poll和epoll IO模型的详解

    http://blog.csdn.net/tianmohust/article/details/6677985 一).Epoll 介绍 Epoll 可是当前在 Linux 下开发大规模并发网络程序的热 ...

  6. Java Runtime.getRuntime().exec() 执行带空格命令

    可执行文件路径如果包含空格,则在java中不能被获取到. 此时Debug一下,会发现 project=null. project.waitFor 的返回值为1.但是去源路径单击bat文件是可以正常运行 ...

  7. Android WebView挂马漏洞--各大厂商纷纷落马

    本文章由Jack_Jia编写,转载请注明出处.   文章链接: http://blog.csdn.net/jiazhijun/article/details/11131891 作者:Jack_Jia ...

  8. [C++]引用浅析

    Date:2013-12-22 Summary: 引用数据类型的一些概念记录(沟通中提到引用必须结合语境才能知道说的是引用变量还是“引用”这一行为,再次提到引用指的一般是引用变量) Contents: ...

  9. C#向并口设备发送指令以获取并口设备的状态

    using System; using System.Diagnostics; using System.Runtime.InteropServices; using System.Text; usi ...

  10. 建立地方Jekyll周边环境

    近期使用github建立一个博客,只是要了解markdown语法,因为markdown后写的不是立即可见.所以,每一个成品都要经过在线调试,在线调试已经上线的文章,每次上线有反复git add, gi ...