使用多线程在C++中实现归并排序

使用多线程在c++中实现归并排序

我们得到一个未排序的整数数组。任务是使用通过多线程实现的合并排序技术对数组进行排序

合并排序

合并排序是一种基于分而治之技术的排序技术,我们将将数组分成相等的两半,然后以排序的方式将它们组合起来。

实现归并排序的算法是

检查是否有一个元素

否则,将数据递归地分成两半,直到无法再分为止。

立即学习“C++免费学习笔记(深入)”;

最后,按排序顺序将较小的列表合并为新列表。

多线程

在操作系统中,线程是负责执行部分任务的轻量级进程。线程共享公共资源来并发执行任务。

多线程是多任务处理的一种实现,我们可以在单个处理器上运行多个线程来并发执行任务。它将单个应用程序中的特定操作细分为单独的线程。每个线程都可以并行运行。

例如:

In −int arr[] = {3, 2, 1, 10, 8, 5, 7, 9, 4}

输出−排序后的数组为:1, 2, 3, 4, 5, 7, 8, 9, 10

解释-我们得到一个带有整数值的未排序数组。现在我们将使用多线程合并排序对数组进行排序。

In −int arr[] = {5, 3, 1, 45, 32, 21, 50} p>

输出−排序后的数组为:1, 3, 5, 21, 32, 45, 50

解释−我们给出具有整数值的未排序数组。现在我们将使用多线程合并排序对数组进行排序。

下面程序中使用的方法如下 –

我们将开始通过使用 C++ STL 中的 rand() 方法生成随机数。

创建 pthread_t 类型的数组,即 P_TH[thread_size]。

开始从 i 到 0 的 FOR 循环,直到 i 小于线程的大小。在循环内部,调用 pthread_create(&P_TH[i], NULL, Sorting_Threading, (void*)NULL) 方法来创建具有给定数组值的线程。

将函数作为组合数组调用(0、(大小 / 2 – 1) / 2、大小 / 2 – 1)、combine_array(大小 / 2、大小/2 + (大小-1-大小/2)/2、大小 – 1) 和 merge_array(0 , (size – 1)/2, size – 1)

打印存储在整数类型 arr[] 中的排序数组。

函数内部void* Sorting_Threading(void* arg)

声明一个变量为set_val到temp_val++,首先要set_val * (size / 4 ),end 为 (set_val + 1) * (size / 4) – 1,mid_val 为first + (end – first) / 2

检查 IF first 小于 end then调用Sorting_Threading(first, mid_val)、Sorting_Threading(mid_val + 1, end)和combine_array(first, mid_val, end);

里面function void Sorting_Threading(int first, int end)

将变量声明为 mid_val to first + (end – first) / 2

检查 IF 首先小于 end,然后调用 Sorting_Threading(first, mid_val)、Sorting_Threading(mid_val + 1, end) 和 merge_array(first, mid_val, end)

函数内部 void merge_array(int first, int mid_val, int end)

将变量声明为 int* start 到new int[mid_val – first + 1]、int* last 到 new int[end – mid_val]、temp_1 到 mid_val – first + 1、temp_2 到 end – mid_val、i、j、k 到first。

li>

开始从 i 到 0 的 FOR 循环,直到 i 小于 temp_1。在循环内,将 start[i] 设置为 arr[i + first]。

开始从 i 到 0 的 FOR 循环,直到 i 小于 temp_2。在循环内部,将last[i]设置为arr[i + mid_val + 1]

将i设置为j为0。当i小于temp_1并且j小于时开始循环比 temp_2。在此期间,检查 IF start[i] 是否小于 last[j],然后将 arr[k++] 设置为 start[i++]。否则,设置 arr[k++] = last[j++]

当 i 小于 temp_1 时开始,然后设置 arr[k++] = start[i++]。当 j 小于 temp_2 时开始,然后将 arr[k++] 设置为 last[j++]

示例

#include #include #include 

输出

如果我们运行上面的代码,它将生成以下输出

Merge Sort using Multi-threading: 15 21 26 26 27 35 36 40 49 59 62 63 72 77 83 86 86 90 92 93

以上就是使用多线程在C++中实现归并排序的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1444087.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 20:59:36
下一篇 2025年12月13日 16:58:42

相关推荐

  • 在C语言中,寄存器存储类是什么?

    在C编程语言中有四个存储类,分别是: autoexternstaticregister 寄存器变量 关键字是register。 寄存器变量的值存储在CPU的寄存器中,而不是存储在内存中,普通变量存储在内存中。 寄存器是CPU中的临时存储单元。 立即学习“C语言免费学习笔记(深入)”; 它们允许寄存器…

    2025年12月17日
    000
  • 在C语言中,负数的绝对值为正数

    在这里,我们将看到如果我们使用负数来获取模数会得到什么结果。让我们看一下以下程序及其输出,以了解这个概念。 示例 #includeint main() { int a = 7, b = -10, c = 2; printf(“Result: %d”, a % b / c);} 输出 Result: …

    2025年12月17日
    000
  • C语言中的身份矩阵程序

    给定一个方阵 M[r][c],其中“r”是一定数量的行,“c”是列,使得 r = c,我们必须检查“M”是否是单位矩阵。 恒等矩阵 恒等矩阵也称为大小为nxn方阵的单位矩阵,其中对角元素的整数值为1,非对角元素的整数值为0 p> 就像下面给定的示例 – $$I1=begin{bma…

    2025年12月17日
    000
  • C++程序打印空心的右三角星形图案

    以金字塔、正方形和菱形等不同格式显示星形图案非常有用常见于基础编程和逻辑构建。我们见过几颗星星学习编程中的循环语句时的数字模式问题。在本文中,我们将看到如何在 C++ 中打印空心直角三角形星形图案。 在此程序中,我们采用行号 n,这将为 n 个数创建一个星形图案线。让我们看一下相同的示例。 右空心星…

    2025年12月17日
    000
  • C/C++标记?

    C++ 令牌是程序的最小独立单元。 C++ 是 C 的超集,因此大多数 C 结构在 C++ 中都是合法的,其含义和用法不变。因此,标记、表达式和数据类型与 C 的标记、表达式和数据类型类似。 以下是 C++ 标记:(大多数 C++ 标记基本上与 C 标记类似) 关键字标识符常量变量运算符 关键字 关…

    2025年12月17日
    000
  • 使用C++编写的代码:找到使用字母表前K个字母组成的字典序最小的字符串,且相邻字符不能相同

    在编程世界中,解决字符串操作问题是一个常见且有趣的挑战。面临的一个关键问题是如何仅利用字母表中的 K 个字母来获得按字典顺序排列的最小字符串,同时遵循诸如不匹配相邻字符之类的附加约束。在本文中,我们的目的是深入研究这个问题并使用 C++ 编程语言提出有效的解决方案。通过详细介绍语法中使用的不同方法并…

    2025年12月17日
    000
  • Klee的算法(线段的并集长度)在C++中

    在本教程中,我们将编写一个程序,用于查找线段的并集的长度。 我们已经给出了线段的起点和终点,我们需要找到线段的并集的长度。 我们将使用的算法称为klee’s算法。 让我们来看看解决这个问题的步骤。 立即学习“C++免费学习笔记(深入)”; 用所有线段的坐标初始化数组。初始化一个名为poi…

    2025年12月17日
    000
  • 在C++中,将给定的四个数字组成的第n个数字的位数

    We need to find the number of digits in the nth number made of given four digits 1, 2, 3, and 4. The series with the above four digits is as follows 1…

    2025年12月17日
    000
  • 在C语言中的布尔数组谜题

    这是一个基于数组的谜题,需要你将包含两个元素的数组中的所有数字都更改为0。数组的一个元素是0,另一个元素可能是0也可能不是。 要解决这个谜题,程序需要找到非零元素并将其更改为0。 以下是解决布尔数组谜题所需的约束条件 − 允许的操作是补集,其他操作不允许。不允许使用循环和条件语句。也不允许直接赋值。…

    2025年12月17日
    000
  • c语言大小写字母怎么转化

    c语言大小写字母转化的方法:1、tolower()函数,使用for循环来遍历字符串中的每个字符,将每个字符传递给tolower()函数进行转换,并将转换结果赋值给原来的字符,最后打印转换后的字符串;2、toupper()函数,使用for循环来遍历字符串中的每个字符,将每个字符传递给toupper()…

    2025年12月17日
    000
  • 在C语言中,转义序列

    许多编程语言支持一种称为转义序列的概念。当一个字符前面有一个反斜杠()时,它被称为转义序列,并且对编译器有特殊的意义。例如,下面的语句中的 是一个有效的字符,它被称为换行字符 − char ch = ”;在这里,字符n之前有一个反斜杠(),它具有特殊含义,即换行,但请记住反斜杠()只对一些字符具有…

    2025年12月17日
    000
  • 在C语言中编写一个程序来打印菱形图案

    程序描述 钻石图案是简单金字塔图案和倒金字塔图案的组合。 算法 First Row: Display 1Second Row: Display 1,2,3Third Row: Display 1,2,3,4,5Fourth Row: Display 1,2,3,4,5,6,7Fifth Row: D…

    2025年12月17日
    000
  • c语言画皮卡丘代码怎么写

    编写步骤:1、在C语言中安装图形库;2、使用“initgraph”函数初始化图形库,并设置绘图窗口的大小和位置;2、使用“setcolor”函数设置绘图的颜色,使用“circle”函数绘制圆形,使用`arc`函数绘制弧线,使用“ellipse”函数绘制椭圆;3、使用“getch”函数等待用户按下任意…

    2025年12月17日
    000
  • 使用C++移除两个零之间的元素

    在本文中,我们将讨论如何从一个只包含0和1字符的给定字符串中删除两个零之间的元素。最终的字符串不应包含任何被0包围的字符’1’。例如- Input : string = “110010”Output : “11000”Expla…

    2025年12月17日
    000
  • 使用C++编写一个找到数字的程序,其数字的各位数之和为偶数的程序

    能被2整除的整数是偶数。因此在本文中,我们给定了一个数n,我们需要找到第n个数字,其数字之和为偶数。前五个数字的数字之和为偶数的数分别是2、4、6、8和11。例如 − Input : n = 5Output : 11Explanation : First 5 numbers with even su…

    2025年12月17日
    000
  • 如何使用C语言以Pascal三角形的形式打印整数?

    pascal的三角形是以三角形的形式表示整数的一种方法。其中一个著名的表示方法是使用二项式方程。我们可以使用组合和阶乘来实现这一点。 构建Pascal三角形 三角形外的所有值都被视为零(0)。第一行是0 1 0,而只有1在Pascal的三角形中占据一个空间,0是看不见的。第二行是通过添加(0+1)和…

    2025年12月17日
    000
  • 在C语言中编写一个程序来打印实心和空心菱形图案

    程序说明 打印如下所示的实心和空心菱形图案 算法 对于空心菱形 – Accept the Number of Rows for Hollow Rhombus from the UserCreate a Hollow Rhombus containing the same number o…

    2025年12月17日
    000
  • C和C++之间的不兼容性

    在这里,我们将看到C和C++之间的一些不兼容性。一些可以使用C编译器编译的C代码,在C++编译器中无法编译。并且会返回错误。 我们可以使用一种语法来定义函数,该语法在参数列表之后可选择指定参数类型。 示例 #includevoid my_function(x, y)int x;int y; { //…

    2025年12月17日
    000
  • Kruskal的最小生成树算法-贪婪算法在C++中

    生成树是连接所有顶点的有向无向图子图。图中可以存在许多生成树。每个图上的最小生成树(mst)的权重相同或小于所有其他生成树。权重被分配给生成树的边,总和是分配给每个边的权重。由于 v 是图中的顶点数,因此最小生成树的边数为 (v – 1),其中 v 是边数。 使用 Kruskal 算法查…

    2025年12月17日
    000
  • 如何使用C语言中的for循环打印用户选择的一个月份的日历?

    The logic to print a one-month calendar is as follows − for(i=1;i<first;i++) printf(" ");for(i=1;i<=noofdays;i++){ printf("%3d&qu…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信