参考

C语言冒泡排序算法及代码  有详细解释

《数据结构》 陈越 等编著

esort.c 代码如下,可关注下mallloc/free,freopen重定向的用法,排序为每轮将最小的数放在前面:

#include<stdio.h>
#include<malloc.h> #define N 100 int datin(int *p);
void printout(int *p,int len);
void esort(int *p,int len); int main(void)
{
int len=;
int *a,*ptrinit;
a = (int *)malloc(sizeof(int)*N);
ptrinit = a;
if(a == NULL)
{
printf("a malloc err!\n");
return -;
}
len = datin(a);
printf("\n input data len = %d:\n",len);
printf("\n input data :\n");
printout(a,len);
esort(a,len);
printf("\n esort data :\n");
printout(a,len); free(a);
printf("\n--exit--\n");
return ;
} void esort(int *p,int len)
{
int i=,j=;
int temp = ;
for(i=; i<len; i++)
for(j=; j<len-i-; j++)
{
if(p[j] > p[j+])
{
temp = p[j+];
p[j+] = p[j];
p[j] = temp;
}
}
} int datin(int *p)
{
int len = ;
freopen("data.txt","r",stdin); //data input
while(scanf("%d",p)!=EOF)
{
len++;
p++;
}
fclose(stdin);
return len;
} void printout(int *p,int len)
{
int i=;
while(i<len)
{
printf("%d\t",*p);
p++;
i++;
}
}
 注意如下函数,形参int *p为整型指针类型:
int datin(int *p)
{
int len = ;
freopen("data.txt","r",stdin); //data input
while(scanf("%d",p)!=EOF)
{
len++;
p++;
}
fclose(stdin);
return len;
}

1)在输入和输出数据的函数中,指针做形参时,在函数中是不会修改指针的地址的,只能修改指针所指向的内容,即 *p。

2)结合栈(stack)的理解,函数传递的参数和临时变量都是保存在 栈里面的,在函数退出时,栈里面的内容会被释放掉。

3)所以,指针的地址是不会被改变的,就算是 在函数中做了p++的操作。通过scanf改变了 (*p)的数值

Makefile

CC := gcc

all:esort_min esort_max

esort_min: esort_min.o
$(CC) $^ -o $@ esort_min.o: esort_min.c
$(CC) -c $^ esort_max: esort_max.o
$(CC) $^ -o $@ esort_max.o: esort_max.c
$(CC) -c $^ clean:
rm -f *.o esort_min esort_max

执行情况:

hy@ubuntu:~/ccc/pjesort$ ./esort_min

 input data len = :

 input data :

 esort data :

--exit--
hy@ubuntu:~/ccc/pjesort$ ./esort_max input data len = : input data : esort data : --exit--
hy@ubuntu:~/ccc/pjesort$

冒泡排序改进算法

// coding by microhy
//
#include <stdio.h>
#include <stdlib.h>
//#include <string.h>
//#include <ctype.h>
#define MAXLEN (100) int data_input(int *a)
{
int *ptri=a;
int cnt = ;
if(ptri==NULL)
{
return -;
}
while(scanf("%d",ptri)!=EOF)
{
ptri++;
cnt++;
}
return cnt;
} void data_output(int *a,int N)
{
int i=;
while(i<N)
{
printf("%d\t",*a);
i++;
a++;
}
printf("\n");
} void BuddleSort(int *a,int N)
{
int i,j,temp;
int flag=;
for(i=; i<N; i++)
{
flag=;
for(j=; j<N-i-; j++)
{
if(a[j] > a[j+])
{
temp = a[j+];
a[j+] = a[j];
a[j] = temp;
flag = ;
}
}
if(!flag)
break;
}
} int main()
{
int dat_len=;
int *datArry=NULL; datArry = (int *)malloc(sizeof(int)*MAXLEN);
if(datArry==NULL)
{
printf("[err]NULL, Pls Check datArry malloc\n");
return -;
}
#if 1 // !!
freopen("in.txt","r",stdin);
printf("\t!!! < Pls freopen off > !!!\n");
//freopen("out.txt","w",stdout);
#endif // dat_len = data_input(datArry);
if(dat_len&&dat_len<=MAXLEN)
{
data_output(datArry,dat_len);
BuddleSort(datArry,dat_len);
data_output(datArry,dat_len);
}
free(datArry); // !!!
return ;
}

代码链接:

http://pan.baidu.com/s/1pLM0ILH

http://pan.baidu.com/s/1slHkUAD

以冒泡排序为例--malloc/free 重定向stdin stdout的更多相关文章

  1. 重定向stdin stdout stderr |

    在Linux下,当一个用户进程被创建的时候,系统会自动为该进程创建三个数据 流,也就是题目中所提到的这三个.那么什么是数据流呢(stream)? 我们知道,一个程序要运行,需要有输入.输出,如果出错, ...

  2. WorkerMan源码分析(resetStd方法,PHP中STDIN, STDOUT, STDERR的重定向)

    WorkerMan中work.php中 resetStd 方法中代码如下 public static function resetStd() { if (!static::$daemonize || ...

  3. stdin stdout stderr 标准I/O流

    Unix中一切皆文件,磁盘等设备在操作系统来看都是文件. 对文件进行操作时,需要打开这个文件,并获得文件描述符(file descriptor, fd) 而每个进程生来就有三个文件描述符绑定在它身上, ...

  4. shell基础知识之 stdin,stdout,stderr和文件描述符

    stdin,stdout,stderr stdin=0 stdout=1 stderr=2 使用tee来传递内容,把stdout 作为stdin 传到下个命令 root@172-18-21-195:/ ...

  5. stdin stdout stderr - 标准 I/O 流

    Fd #include <stdio.h> Fd extern FILE *stdin; Fd extern FILE *stdout; Fd extern FILE *stderr; D ...

  6. vbs脚本要求在cmd中输入输出用StdIn ,StdOut

    Dim StdIn, StdOutSet StdIn = WScript.StdInSet StdOut = WScript.StdOut Do While Not StdIn.AtEndOfStre ...

  7. Linux学习笔记 -- stdin/stdout 重定向

    输入/输出重定向 Linux系统通常从一个叫标准输入的地方读取输入并且将一个命令的结果以写入到标准输出反馈给我们:默认情况下,这也是我们使用的终端(命令行).如果我们想改变输入和输出的方式,就需要使用 ...

  8. Linux Shell 文件描述符 及 stdin stdout stderr 重定向

    Abstract: 1) Linux Shell 命令的标准输入.标准输出.标准错误,及其重定位: 2)Linux Shell 操作自定义文件描述符: 文件描述符是与文件相关联的一些整数,他们保持与已 ...

  9. 利用stdin stdout stderr及POSIX-linux机制重定向写日志

    由open返回的文件描述符一定是该进程尚未使用的最小描述符.由于程序启动时自动打开文件描述符0.1.2,因此第一次调用open打开文件通常会返回描述符3,再调用open就会返回4.可以利用这一点在标准 ...

随机推荐

  1. WPF 自定义滑动ScrollViewer

    自定义滑动滚动条 预期目标:横向滚动条,可以左右滑动,用鼠标按住(触摸)然后释放可以实现快速滑动. 我们有几种方案: 1.ScrollViewer,修改其中的横向滚动条,将其中的背景设置为透明. 但是 ...

  2. 复选框checkbox选中个数限制

    今天遇到一个问题:就是项目里有用到限制 checkbox框选中个数,看起来很简单,但是确实花了点时间才弄清楚,废话不多说,上代码 <!DOCTYPE html> <html lang ...

  3. 优化IPOL网站中基于DCT(离散余弦变换)的图像去噪算法(附源代码)。

    在您阅读本文前,先需要告诉你的是:即使是本文优化过的算法,DCT去噪的计算量依旧很大,请不要向这个算法提出实时运行的苛刻要求. 言归正传,在IPOL网站中有一篇基于DCT的图像去噪文章,具体的链接地址 ...

  4. Linux下的ctrl常用组合键

    在linux的命令模式下使用ctrl组合键能让操作更便捷. ctrl + k -- 剪切光标及其后边的内容: ctrl + u -- 剪切光标之前的内容: ctrl + y -- 在光标处粘贴上两个命 ...

  5. [原]CentOS7 部署GeoServer2.92

    转载请注明作者think8848和出处(http://think8848.cnblogs.com) 1. 安装Jre 1. 安装ftp客户端 sudo yum install ftp -y 2. 登录 ...

  6. C#获取CPU占用率、内存占用、磁盘占用、进程信息

    代码: using System; using System.Collections.Generic; using System.Diagnostics; using System.Threading ...

  7. .Net Core Logger 实现log写入本地文件系统

    .net core 自带一个基础的logger框架Microsoft.Extensions.Logging. 微软默认实现了Microsoft.Extensions.Logging.Console.d ...

  8. php设计模式--面向对象

    php链式操作的实现: 特点:1.链式操作一般存在于面向对象的情况下链式操作才有意义 /* * SQL语句组合实例类,始发文章web开发笔记 * 学习用,非专业类 * */ class sql{ pr ...

  9. 读《单页web应用》-回顾作用域

    js中没有块级作用域,只有全局作用域和函数作用域.全局变量可以在任何地方访问,局部变量只能在声明它的地方访问. var a=1; function func(){ var a=2; } console ...

  10. js文件中函数前加分号和感叹号是什么意思?

    本文转自:http://blog.csdn.net/h_o_w_e/article/details/51388500 !function(){}();   !有什么用? 从语法上来开,JavaScri ...