使用C语言编写的二分查找程序,使用pthread进行多线程处理

使用c语言编写的二分查找程序,使用pthread进行多线程处理

我们知道二分查找方法是一种最适合和有效的排序算法。这个算法适用于已排序的序列。算法很简单,它只是从中间找到元素,然后将列表分成两部分,并向左子列表或右子列表移动。

我们知道它的算法。现在我们将看到如何在多线程环境中使用二分查找技术。线程的数量取决于系统中存在的核心数。让我们看一下代码以了解思路。

示例

#include #define MAX 16#define MAX_THREAD 4using namespace std;//place arr, key and other variables as global to access from different threadint arr[] = { 1, 6, 8, 11, 13, 14, 15, 19, 21, 23, 26, 28, 31, 65, 108, 220 };int key = 31;bool found = false;int part = 0;void* binary_search(void* arg) {   // There are four threads, each will take 1/4th part of the list   int thread_part = part++;   int mid;   int start = thread_part * (MAX / 4); //set start and end using the thread part   int end = (thread_part + 1) * (MAX / 4);   // search for the key until low < high   // or key is found in any portion of array   while (start  key)         end = mid - 1;      else         start = mid + 1;   }}main() {   pthread_t threads[MAX_THREAD];   for (int i = 0; i < MAX_THREAD; i++)      pthread_create(&threads[i], NULL, binary_search, (void*)NULL);   for (int i = 0; i < MAX_THREAD; i++)      pthread_join(threads[i], NULL); //wait, to join with the main thread   if (found)      cout << key << " found in array" << endl;   else      cout << key << " not found in array" << endl;}

输出

31 found in array

以上就是使用C语言编写的二分查找程序,使用pthread进行多线程处理的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 20:05:03
下一篇 2025年12月14日 14:54:49

相关推荐

  • C语言标准

    在这个问题中,我们将学习C编程语言中定义的标准。这些是开发社区定义的编译器理想情况下编译程序的标准方式。 为了理解我所说的,以一个常见的C程序为例,你们都一定遇到过并且看到了问题,但没有深入研究。 main()函数的void返回类型- 看下面的程序- 立即学习“C语言免费学习笔记(深入)”; voi…

    2025年12月17日
    000
  • C语言中的条件编译#if怎么用?有哪些用法?

    c语言中#if的作用是根据条件决定代码是否参与编译,其基本用法为#if后跟常量表达式,值为真则编译代码块,否则跳过。1. 常用于临时屏蔽代码,避免注释嵌套问题;2. 结合宏定义可控制不同构建配置下的代码行为,如调试输出;3. 支持多重判断#elif和#else,适配多平台环境;4. 搭配#ifdef…

    2025年12月17日
    000
  • c语言中的ave什么意思 ave在c语言中的平均值变量

    在c语言中,”ave”通常是”average”的缩写,用于表示平均值。1) 使用float或double类型存储平均值,避免精度损失;2) 注意溢出问题,特别是大数据量时;3) 考虑性能优化,如使用并行计算;4) 处理边界情况,如空数组;5) 根据需求…

    2025年12月17日
    000
  • C#的元组类型是什么?如何使用?

    C#元组是一种轻量级、灵活的值类型数据结构,用于封装多个不同类型的数据,适用于多值返回、临时数据组合等场景。它支持元素命名和解构赋值,显著提升代码可读性与简洁性,尤其在异步编程和LINQ查询中表现优异。相比匿名类型和结构体,元组更适合无明确业务语义的临时性数据打包,避免定义冗余类型,提高开发效率。 …

    2025年12月17日
    000
  • C语言中的do-while循环怎么用?和while有什么区别?

    do-while循环在c语言中是以后测试方式运行,即先执行一次循环体再判断条件,适用于至少执行一次的场景。1. do-while会先执行循环体,然后检查条件,适合菜单选择和输入验证等需要至少执行一次的情况;2. while循环则是先判断条件,可能一次都不执行;3. do-while语法结构末尾必须加…

    2025年12月17日
    000
  • Z在c语言中表示的数值 大写Z在c语言中的ASCII码值

    大写字母z在c语言中的ascii码值是90。了解ascii码值对编程重要,因为它帮助理解字符的底层表示,并在排序、比较、转换等操作中发挥作用。 大写字母Z在C语言中的ASCII码值是90。 现在,让我们深入探讨一下在C语言中如何使用ASCII码值,以及为什么了解ASCII码值对编程来说非常重要。 在…

    2025年12月17日
    000
  • swap在c语言中代表什么 swap函数在c语言中的变量交换

    在c语言中,swap函数通过指针或宏来交换变量值。1)使用指针交换整数,需考虑类型安全性和错误处理。2)宏定义可实现类型无关交换,但有局限性。3)对于大型结构体,可用xor算法优化。 在C语言中, swap 通常指的是交换两个变量的值。让我们深入探讨一下这个概念,具体到实现swap函数的细节和注意事…

    2025年12月17日
    000
  • C语言中怎样实现栈结构 C语言栈的数组与链表实现对比

    栈在c语言中可用数组或链表实现,各有优劣。1. 数组栈实现简单、访问速度快,但容量固定、扩展性差;2. 链表栈灵活可扩展、无需预设大小,但实现较复杂、访问速度慢且需额外内存存指针。性能上,数组栈通常更快因其内存连续,利于缓存;而链表栈在频繁扩展时更优。选择时若容量已知且稳定,选数组栈;若需动态扩展或…

    2025年12月17日 好文分享
    000
  • C#的switch表达式和switch语句有何区别?

    switch语句用于控制流程,执行不同操作,适合有副作用的场景;2. switch表达式用于计算并返回值,语法更简洁,支持模式匹配,适合映射和转换;3. switch表达式无穿透问题,自动终止,提升安全性和可读性;4. switch语句在执行i/o、修改状态等副作用操作时更适用;5. 两者性能差异可…

    2025年12月17日
    000
  • C语言中的strcpy和strncpy有什么区别?怎么用?

    strcpy和strncpy的主要区别在于安全性与复制方式。strcpy直接复制整个字符串,不检查目标缓冲区大小,易导致缓冲区溢出;而strncpy通过限制复制字符数n提升安全性,但不会自动添加结束符,需手动处理。使用strcpy时必须确保dest空间足够,建议避免在不确定输入长度时使用;strnc…

    2025年12月17日
    000
  • 在c语言中怎么用 换行符 在c语言中的使用场景

    在 c 语言中, 用于创建新行,广泛应用于格式化输出和文件处理。1) 格式化输出:如打印日志和生成报告。2) 文件处理:如读取csv文件。3) 跨平台开发需注意不同系统对换行符的处理。 在 C 语言中,换行符 是一个非常常见且重要的字符,它用于在输出时创建新行。简单来说, 告诉编译器在输出时跳到下一…

    2025年12月17日
    000
  • C语言中的内联函数是什么?怎么定义?

    内联函数用于减少函数调用开销,通过将函数体插入调用处来提升效率。频繁调用的小函数适合内联,如数学运算函数,相比宏定义更安全。定义时在函数前加inline关键字,并通常放在头文件中,但static inline可用于单个源文件。注意:非所有函数都能成功内联,复杂逻辑、递归或循环函数可能无法展开;滥用会…

    2025年12月17日
    000
  • C语言中指针怎么使用C语言指针的基本概念和常见错误

    c语言的指针本质是内存地址,理解这一点后,指针的核心作用在于直接操作内存。1. 指针的基本操作包括声明、赋值和解引用;2. 指针与数组关系密切,数组名即为指向首元素的指针;3. 使用指针需避免空悬指针、野指针和内存泄漏等常见错误;4. 指针运算应注意仅对同一数组内有效且步长由数据类型决定;5. 利用…

    2025年12月17日 好文分享
    000
  • C语言中static变量怎么声明C语言static变量的生命周期分析

    局部静态变量作用域限于函数内部,生命周期贯穿整个程序运行期间;全局静态变量作用域限于当前文件内,生命周期同样贯穿整个程序运行期间。1. 局部静态变量在函数内部声明,仅该函数可访问,初始化发生在第一次调用时且值保持至程序结束。2. 全局静态变量在函数外部声明,仅当前文件可访问,初始化在程序启动时完成。…

    2025年12月17日 好文分享
    000
  • C语言中多线程同步怎么实现C语言互斥锁和条件变量的使用

    c语言实现多线程同步的核心在于互斥锁和条件变量的合理使用。1. 互斥锁(mutex)用于保护共享资源,通过pthread_mutex_init初始化,pthread_mutex_lock加锁,pthread_mutex_unlock解锁,防止数据竞争;2. 条件变量(condition variab…

    2025年12月17日 好文分享
    000
  • C语言中JSON怎么解析C语言cJSON库的安装和使用教程

    c语言中解析json的常用库是cjson,它轻量且易于集成。1. 下载cjson源码;2. 将cjson.c和cjson.h加入项目;3. 编译时包含cjson.c。使用时通过cjson_parse解析json字符串,通过cjson_getobjectitemcasesensitive获取字段值,并…

    2025年12月17日 好文分享
    000
  • c语言中%lf是什么意思 %lf在c语言中的格式化输出用法

    在c语言中,%lf用于格式化输出double类型的数据。1)%lf明确表示输出double类型,提高代码可读性。2)使用%lf输出时,默认6位小数,可通过%.2lf控制小数位数。3)使用scanf时,建议用%lf读取double类型数据。4)%lf在现代编译器中兼容性好,但老版本可能需用%f。5)%…

    2025年12月17日
    000
  • C语言中的位运算符&和|怎么用?有哪些应用?

    按位与(&amp;amp;)和按位或(|)是c语言中用于操作二进制位的重要运算符。1. 按位与(&amp;amp;)的规则是两个对应位都为1时结果才为1,可用于提取特定位或清零某些位;2. 按位或(|)的规则是任意一个对应位为1则结果为1,常用于设置特定位为1或合并多个标志位;3. …

    2025年12月17日
    000
  • c语言中break和continue的区别是什么_break和continue有什么区别

    break和continue在c语言中用于控制循环流程,但作用不同。1.break会立即终止整个循环,程序控制权转移到循环之后的下一条语句,适用于提前结束循环的情况,例如搜索到目标元素时;2.continue则跳过当前循环迭代的剩余部分,直接进入下一次循环迭代,适用于跳过某些特定条件下的循环体执行,…

    2025年12月17日 好文分享
    000
  • C语言中的编译器优化有哪些选项?怎么使用?

    在C语言开发中,编译器优化是一个非常实用的功能,能帮助你提升程序的运行效率、减少资源占用。不同的编译器(比如GCC、Clang、MSVC)有不同的优化选项,但最常用的是GCC系列,下面主要以GCC为例来说明。 1. GCC常见的优化等级 GCC提供了几个预设的优化等级,使用 -O 加上数字或字母来控…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信