[C语言]排序问题–我的解答

问题的在这里:http://www.cnblogs.com/amboyna/archive/2010/02/08/1666002.html 答案:LINUX下GCC编译通过

问题的在这里:http://www.cnblogs.com/amboyna/archive/2010/02/08/1666002.html

答案:LINUX下GCC编译通过

#include <stdio.h>
#include
<stdlib.h>
#include
<string.h>#define MAX 100000int file_name =0 ;

void merge(int nums[], int start, int new_mid, int end);
void qqsort(int a[],int low,int high);
int partions(int a[],int low,int high);
int segment(FILE *fp );


int main()
{
FILE
*fp;
//FILE *fps, *fpa, *fpb, *fpc; fp = fopen("num.txt", "r");
segment(fp);
fclose(fp);
//printf("segment done, total:%d\n", file_name );
//return 0;int p =0, i =0;
char fn[3] ="";
char ch[20] ="";
int cache[file_name];
int cmax;
int t[file_name];
FILE
*fpp[file_name];
fp
= fopen("num_b.txt", "w+");
for(; p < file_name; p++)
{
sprintf(fn,
"%d", p);
fpp[p]
= fopen(fn , "r");
if((fgets(ch, 20, fpp[p])) != NULL)
cache[p]
= atoi(ch);
}

cmax
=0;
while(1)
{
for(p =0; p < file_name; p++)
{
if(cache[p] > cache[cmax])
{
cmax
= p;
}
}
//printf("\n%d\n",cache[cmax]);
//sprintf(fn, "%d", cmax);if(cache[cmax] !=-1)
{
fprintf( fp,
"%d\n", cache[cmax]);
t[cmax]
++;
if((fgets(ch, 15, fpp[cmax])) != NULL)
{
cache[cmax]
= atoi(ch);
}
else
{
cache[cmax]
=-1;
}
}
else
{
fclose(fp);
char num[3];
for(p =0; p < file_name; p++)
{
sprintf(num,
"%d", p);
remove(num);
}
return0;
}

}


return0;
}

int partions(int a[],int low,int high)
{
int pivotkey=a[low];
int s;
s
=a[low];
while(low<high)
{
while(low<high && a[high]pivotkey)
--high;
a[low]
=a[high];
while(low<high && a[low]>=pivotkey)
++low;
a[high]
=a[low];
}
a[low]
=s;
return low;
}
void qqsort(int a[],int low,int high)
{

int pivottag;
if(low<high )
{
//递归调用 pivottag=partions(a,low,high);
qqsort(a,low,pivottag
-1);
qqsort(a,pivottag
+1,high);
}
}

int write_file(FILE *fp, int nums[])
{
qqsort(nums ,
0 , MAX-1);
int c =0;
while(1)
{
fprintf( fp,
"%d\n", nums[c]);
if (++c == MAX ) return0;
}
}

int segment(FILE *fp )
{
char ch[20];
char num[3];
int nums[MAX];
int i =0;
FILE
* fpr ;
while(fgets(ch,100, fp) != NULL)
{
if(i MAX){
nums[i]
= atoi(ch);
}
else{
sprintf(num,
"%d", file_name);
fpr
= fopen( num , "w+");
write_file(fpr, nums);
fclose(fpr);
file_name
++;
i
=0;
nums[i]
= atoi(ch);
}

i
++;
}
sprintf(num,
"%d", file_name);
fpr
= fopen( num , "w+");
write_file(fpr, nums);
fclose(fpr);
file_name
++;
return0;
}

其实快排还是可以进一步优化的。

Original: https://www.cnblogs.com/amboyna/archive/2010/03/02/1676442.html
Author: 玉米疯收
Title: [C语言]排序问题–我的解答

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/535080/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 一道C语言安全编码题目

    1、前言 最近在网上看到一道C语言题目,用C语言实现一个函数,给定一个int类型的整数,函数输出逆序的整数,例如输入123,则输出字符串”321″,,输入-…

    C语言 2023年5月29日
    053
  • JavaSE assert断言的学习

    在Java中,assert关键字是从JAVA SE 1.4 引入的,为了避免和老版本的Java代码中使用了assert关键字导致错误,Java在执行的时候默认是不启动断言检查的(这…

    C语言 2023年5月29日
    058
  • 互联网世界中的C语言——我的golang学习笔记:1(基础语法快速过)

    wangyishuaideMacBook-Pro:goStu wangyishuai$ rm hello wangyishuaideMacBook-Pro:goStu wangyi…

    C语言 2023年5月29日
    087
  • Floyd算法(一)之 C语言详解

    和Dijkstra算法一样,弗洛伊德(Floyd)算法也是一种用于寻找给定的加权图中顶点间最短路径的算法。该算法名称以创始人之一、1978年图灵奖获得者、斯坦福大学计算机科学系教授…

    C语言 2023年5月29日
    051
  • C语言的原码,反码,补码

    1)原码表示 原码表示法是机器数的一种简单的表示法。其符号位用0表示正号,用:表示负号,数值一般用二进制形式表示。设有一数为x,则原码表示可记作[x]原。 例如,X1= +1010…

    C语言 2023年5月29日
    077
  • C语言指针总结大学霸IT达人

    C语言指针总结大学霸IT达人 C语言的指针是C语言区别其它语言的最主要的特定之一。有了指针,C语言就可以抛开所有束缚,直接对内存中的数据进行操作,这样,不单对数据的操作更加快捷,并…

    C语言 2023年5月29日
    054
  • C语言实现粒子群算法(PSO)一

    最近在温习C语言,看的书是《C primer Plus》,忽然想起来以前在参加数学建模的时候,用过的一些智能算法,比如遗传算法、粒子群算法、蚁群算法等等。当时是使用MATLAB来实…

    C语言 2023年5月29日
    047
  • Crystal 软件学堂:每周一练【C语言】

    欢迎加入作者的小圈子 扫描下方左边二维码加入QQ交流群,扫描下方右边二维码关注个人微信公众号并获取更多隐藏干货,QQ交流群:816747642 微信公众号:Crystal软件学堂 …

    C语言 2023年5月29日
    054
  • Picoc C语言解释器简介,及STM32平台移植工程

    Picoc是google开源代码项目中看到的一个项目,其初衷貌似是要做一个在小的嵌入设备上的C解释器。它的核心代码只有3500行左右,可读性不错,虽然没有实现完整的ISO C标准,…

    C语言 2023年5月29日
    054
  • C语言实现简易log工具

    0x0 目的 0x1 不用 cout 0x2 不直接用 printf 0x3 用宏实现,而不用函数实现 0x4 简易实现 0x41 最简实现 0x42 打印行号、文件名、自动换行 …

    C语言 2023年5月29日
    056
  • 重学C语言

    重学C语言 1 #include 2 3 int main() 4 { 5 int age = 10; 6 int height = 72; 7 8 printf("I …

    C语言 2023年5月29日
    067
  • 拓扑排序(一)之 C语言详解

    拓扑排序(Topological Order)是指,将一个有向无环图(Directed Acyclic Graph简称DAG)进行排序进而得到一个有序的线性序列。 这样说,可能理解…

    C语言 2023年5月29日
    059
  • c语言-动态内存分配(上课)

    源程序: include //主菜单void menu(){printf(“\n****\n”);printf(“1. 创建单链表\n&#822…

    C语言 2023年5月29日
    047
  • 快速学习C语言二: 编译自动化, 静态分析, 单元测试,coredump调试,性能剖析

    上次的Hello world算是入门了,现在学习一些相关工具的使用 写好程序,首先要编译,就用gcc就好了,基本用法如下 helloworld.c是源码,helloworld.o是…

    C语言 2023年5月29日
    058
  • c语言 结构体(二)-上课用

    源程序: //编写一个函数print,输出学生的信息,该数组有5个学生的记录,包括://num, sname, score[3],用主函数输入这些记录,用print函数输出这些记录…

    C语言 2023年5月29日
    065
  • 理解C语言声明的优先级规则

    A 声明从它的名字开始读取,然后按照优先级顺序依次读取。 B 优先级从高到低依次是: B.1 声明中被括号括起来的那部分 B.2 后缀操作符: 括号()表示这是一个函数,而 方括号…

    C语言 2023年5月29日
    051
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球