网站导航免费论文 原创论文 论文搜索 原创论文 网学软件 学术大家 资料中心 会员中心 问题解答 原创论文 论文素材 设计下载 最新论文 下载排行 论文上传 在线投稿 联系我们
返回网学首页
网学联系
最新论文 推荐专题 热门论文 素材专题
当前位置: 网学 > 编程文档 > VC++ > 正文
VC中利用多线程技术实现线程之间的通信
来源:Http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 12/10/15
下载{$ArticleTitle}原创论文样式
结束
 delete data1;
 delete data2;
 delete data3;
 delete data4;
 CloseHandle(evtPrint);
 return 0;
}

/*
冒泡排序思想(升序,降序同理,后面的算法一样都是升序):从头到尾对数据进行两两比较进行交换,小的放前大的放后。这样一次下来,最大的元素就会被交换的最后,然后下一次
循环就不用对最后一个元素进行比较交换了,所以呢每一次比较交换的次数都比上一次循环的次数少一,这样N次之后数据就变得升序排列了*/
unsigned long __stdcall BubbleSort(void* theArray)
{
 long* Array = ((MySafeArray*)theArray)->data;
 int iLength = ((MySafeArray*)theArray)->iLength;
 int i, j=0;
 long swap;
 for (i = iLength-1; i >0; i--)
 {
  for(j = 0; j < i; j++)
  {
   if(Array[j] >Array[j+1]) //前比后大,交换
   {
    swap = Array[j];
    Array[j] = Array[j+1];
    Array[j+1] = swap;
   }
  }
 }
 PrintResult(Array, iLength, "Bubble Sort"); //向控制台打印排序结果
 InterlockedIncrement(&ThreadCompleted); //返回前使线程完成数标记加1
 if(ThreadCompleted == 4) SetEvent(evtTerminate); //检查是否其他线程都已执行完
 //若都执行完则设置程序结束信号量
 return 0;
}

/*选择排序思想:每一次都从无序的数据中找出最小的元素,然后和前面已经有序的元素序列的后一个元素进行交换,这样整个源序列就会分成两部分,前面一部分是已经排好序的有序序列,后面一部分是无序的,用于选出最小的元素。循环N次之后,前面的有序序列加长到跟源序列一样长,后面的无序部分长度变为0,排序就完成了。*/
unsigned long __stdcall SelectSort(void* theArray)
{
 long* Array = ((MySafeArray*)theArray)->data;
 int iLength = ((MySafeArray*)theArray)->iLength;
 long lMin, lSwap;
 int i, j, iMinPos;
 for(i=0; i < iLength-1; i++)
 {
  lMin = Array[i];
  iMinPos = i;
  for(j=i + 1; j <= iLength-1; j++) //从无序的元素中找出最小的元素
  {
   if(Array[j] < lMin)
   {
    iMinPos = j;
    lMin = Array[j];
   }
  }
  //把选出的元素交换拼接到有序序列的最后
  lSwap = Array[i];
  Array[i] = Array[iMinPos];
  Array[iMinPos] = lSwap;
 }
 PrintResult(Array, iLength, "Select Sort"); //向控制台打印排序结果
 InterlockedIncrement(&ThreadCompleted); //返回前使线程完成数标记加1
 if(ThreadCompleted == 4) SetEvent(evtTerminate);//检查是否其他线程都已执行完
 //若都执行完则设置程序结束信号量
 return 0;
}

/*堆排序思想:堆:数据元素从1到N排列成一棵二叉树,而且这棵树的每一个子树的根都是该树中的元素的最小或最大的元素这样如果一个无序数据集合是一个堆那么,根元素就是最小或最大的元素堆排序就是不断对剩下的数据建堆,把最小或最大的元素析透出来。下面的算法,就是从最后一个元素开始,依据一个节点比父节点数值大的原则对所有元素进行调整,这样调整一次就形成一个堆,第一个元素就是最小的元素。然后再对剩下的无序数据再进行建堆,注意这时后面的无序数据元素的序数都要改变,如第一次建堆后,第二个元素就会变成堆的第一个元素。*/
unsigned long __stdcall HeapSort(void* theArray)
{
 long* Array = ((MySafeArray*)theArray)->data;
 int iLength = ((MySafeArray*)theArray)->iLength;
 int i, j, p;
 long swap;
 for(i=0; i {
  for(j = iLength - 1; j>i; j--) //从最后倒数上去比较字节点和父节点
  {
   p = (j - i - 1)/2 + i; //计算父
  • 上一篇资讯: 利用OpenGL实现三维绘图
  • 网学推荐

    免费论文

    原创论文

    浏览:
    设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
    版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
    Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
    湘ICP备09003080号