C语言实现多线程排序
#include <stdio.h>
#include <pthread.h>
#include <stdlib.h>
#include <string.h> /* 声明变量 */
int array_length, file_length;
int *array_master;
FILE *freader; /* 用于从文件读取数据 */
int *read_file(char *fname)
{
freader = fopen(fname, "rt"); /* 只读方式打开文件 */
int bufsize = file_length; /* 数组规模 */
char line[];
int integer;
int index = ;
int *input = (int *)malloc(bufsize*sizeof(int)); /* 动态分配内存空间 */ while (fgets(line, , freader) != NULL)
{
sscanf(line, "%d", &integer); /*从字符串 line 中获得整数(完成字符串到整数的转换)*/
input[index] = integer;
++index;
++array_length;
} fclose(freader); /* 关闭文件 */
return input;
} /* 求文件的行数(也就是数据量)*/
int read_length(char *fname)
{
freader = fopen(fname, "rt"); /* 以只读方式打开文件 */
char line[];
int file_length = ; /* fgets 从数据文件中读数据,每读一行的字符串
(最长为80个字符),读到文件末尾 EOF,返回NULL */
while (fgets(line, , freader) != NULL)
file_length += ;
return file_length;
} /* 归并函数 */
void merge(int arr[], int left, int middle, int right)
{
int i, j, k;
int half1 = middle - left + ; /* 数组前一半的数据量 */
int half2 = right - middle; /* 数组后一半的数据量 */ int first[half1], second[half2]; /* 声明两个临时数组,
保存前半部分数据和后半部分数据 */ /* 从 arr 数组复制 left 到 right 之间前半部分的数据 */
for (i = ; i < half1; i++)
first[i] = arr[left + i]; /* 从 arr 数组复制 left 到 right 之间后半部分的数据 */
for (j = ; j < half2; j++)
second[j] = arr[middle + + j]; i = ;
j = ;
k = left; /* 比较两个临时数组的数,找出当前最小的数,然后按序存入 arr */
while (i < half1 && j < half2)
{ if (first[i] <= second[j])
{
arr[k] = first[i];
++i;
}
else
{
arr[k] = second[j];
j++;
} k++; /* arr 数组的索引 */
} /* 将临时数组中剩余的数存入 arr 数组 */
while (i < half1)
{
arr[k] = first[i];
i++;
k++;
} while (j < half2)
{
arr[k] = second[j];
j++;
k++;
}
} /* 归并排序函数 */
void* merge_sort(void* arg)
{
/* 变量声明 */
int *arr = array_master; /* 指向全局变量 array_master 数组 */
int *argu = (int*)arg;
int l = argu[]; /* 由线程传入的参数,获得要排序数据的最小索引值 */
int r = argu[]; /* 由线程传入的参数,获得要排序数据的最大索引值 */ /* 若 l==r 则不必排序 */
if (l < r)
{
/* 声明两个线程买描述符 */
pthread_t tid1;
pthread_t tid2; /* 声明调用线程处理函数的参数 */
int arg1[];
int arg2[]; int middle;
middle = (l + (r - )) / ;
arg1[] = l;
arg1[] = middle;
arg2[] = middle + ;
arg2[] = r; /* 由于用二分法对数组分成两部分分别排序,
所以存在并行的可能,这里采用多线程 */
pthread_create(&tid1, NULL, merge_sort, arg1);
pthread_create(&tid2, NULL, merge_sort, arg2); /* 这里必须等待两部分数组都已排序完毕,才能进行归并,
所以这里调用 pthread_join 使得线程同步 */
pthread_join(tid1, NULL);
pthread_join(tid2, NULL); /* 此时归并两个已排序子序列 */
merge(arr, l, middle, r);
pthread_exit();
} return NULL;
} /* 主函数 */
int main(int argc, char *argv[])
{
char *fname = argv[]; /* 从命令行中读取数据文件 */ /* 获取数据的长度 */
file_length = read_length(fname); /* 从数据文件中读取数据 */
array_master = read_file(fname); int arg[];
arg[] = ;
arg[] = file_length - ; /* 创建线程执行归并排序 */
pthread_t tid;
pthread_create(&tid, NULL, merge_sort, arg); /* 进程同步 */
pthread_join(tid, NULL); /* 打印已排序数组 */
int j;
for (j = ; j < array_length; j++)
{
if (j == array_length - )
printf("%d\n", array_master[j]); /* 打印已排序数组的最后一个元素 */ else
printf("%d, ", array_master[j]); /* 打印已排序数组的非最后一个元素 */
} return ;
}
C语言实现多线程排序的更多相关文章
- [R语言]R语言使用多线程对数据库进行大批量访问时出现无法连接问题
		
问题描述: 在R中使用多线程对数据库进行写入,在服务器端运行脚本(linux环境),总是在第6-7万个任务线程时,出现无法连接到数据库的问题.任务中断,错误信息为task 6xxxx failed,C ...
 - swift语言之多线程操作和操作队列(下)———坚持51天吃掉大象(写技术文章)
		
欢迎有兴趣的朋友,参与我的美女同事发起的活动<51天吃掉大象>,该美女真的很疯狂,希望和大家一起坚持51天做一件事情,我加入这个队伍,希望坚持51天每天写一篇技术文章.关注她的微信公众号: ...
 - c语言下多线程
		
原文:c语言下多线程 [问题]创建了10个线程,10个线程公用一个线程体,创建如下: int t1=0,t2=1,t3=2,t4=3,t5=4,t6=5,t7=6,t8=7,t9=8,t10=9; i ...
 - Linux多线程实践(7) --多线程排序对比
		
屏障 int pthread_barrier_init(pthread_barrier_t *restrict barrier, const pthread_barrierattr_t *restri ...
 - C语言实现选择排序算法
		
新人新气象,我又来了,C语言实现选择排序.很基础的东西,原理什么的就不扯了. #include <stdio.h> #include <stdlib.h> #include & ...
 - 浅谈iOS开发中多语言的字符串排序
		
一.前言 在iOS开发中,一个经常的场景是利用tableview展示一组数据,以很多首歌曲为例子.为了便于查找,一般会把这些歌曲按照一定的顺序排列,还会加上索引条以便于快速定位. 由于歌曲名可能有数字 ...
 - C 语言实例 - 字符串排序
		
C 语言实例 - 字符串排序 C 语言实例 C 语言实例 按字典顺序排序. 实例 #include<stdio.h> #include <string.h> int main( ...
 - YTU 2427: C语言习题 整数排序
		
2427: C语言习题 整数排序 时间限制: 1 Sec 内存限制: 128 MB 提交: 391 解决: 282 题目描述 用指向指针的指针的方法对n个整数排序并输出.要求将排序单独写成一个函数 ...
 - YTU 2426: C语言习题 字符串排序
		
2426: C语言习题 字符串排序 时间限制: 1 Sec 内存限制: 128 MB 提交: 262 解决: 164 题目描述 用指向指针的指针的方法对5个字符串排序并输出.要求将排序单独写成一个 ...
 
随机推荐
- ITIL《信息技术基础架构库》
			
一 概述 1. ITIL 自上世纪70年代开始,个人计算机以及计算机网络开始在欧美发达国家普及.随着时间的推移,信息系统的规模越来越大,人们对信息系统的依赖也越来越强.特别是到了80年代,互联网开始普 ...
 - Java 处理异常
			
Java中 ,catch块和 finally块中都有可能发生异常,这时候就需要 用throw 抛出异常 类似于 C#里方法体中的 throw:
 - 【洛谷 P2051】 [AHOI2009]中国象棋(DP)
			
题目链接 首先想到状压dp,但是\(n,m\)高达100,怎么压? 容易发现,每行每列最多两个象棋,否则就直接gg了. 一个巧妙的设置状态的方式是,只需要记录到当前行有多少列是放了1个炮和2个炮. 然 ...
 - WebSocket转载
			
目录 概述 WebSocket 客户端 WebSocket 服务端 WebSocket 代理 FAQ 完整示例 资料 概述 WebSocket 是什么? WebSocket 是一种网络 ...
 - Winserver-FailoverCluster验证异常
			
Q:新建的2台物理机,组成一个集群,第一遍没有问题,建成后,我想重建所以就destroy掉了,但是在重建时报 错误,尝试了各种清除集群指令和重新安装failover等方法都无效. 以后不在使用Dest ...
 - c# 比较字符串
 - [ipsec][strongswan] strongswan源码分析--(一)SA整体分析
			
strongswan SA分析(一) 1 概念 下面主要介绍两个本文将要阐述的核心概念.他们是SA和SP.注意,这不是一篇不需要背景知识的文章.作者认为你适合阅读接下来内容的的前提是,你已经具备了一下 ...
 - 数据库类型对应Java语言类型表
			
下表列出了基本 SQL Server.JDBC 和 Java 编程语言数据类型之间的默认映射: SQL Server 类型 JDBC 类型 (java.sql.Types) Java 语言类型 big ...
 - goroutine的使用与常见错误
			
goroutine的使用时常见错误 goroutine是Golang 的核心之一,在使用时,一般都要配合channel一起使用. 在使用时,经常会遇到一些错误,包括: 不输出 输出与希望输出不一致 a ...
 - WebAssembly(wasm)是什么?——学习
			
WebAssembly 是一种可以使用非 JavaScript 编程语言编写代码并且能在浏览器上运行的技术方案. 参考文章标题:几张图让你看懂WebAssembly 参考地址:https://www. ...