免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1466 | 回复: 0
打印 上一主题 下一主题

求教:从100W个随机的数据里面找出最大的5个 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-11-09 16:50 |只看该作者 |倒序浏览
从100W个随机的数据里面找出最大的5个。
我选用的是直接选择排序。因为不需要把所有的数都排成有序,我个人觉得直接选择应该会比较快。

生成100w随机数
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <time.h>
  4. main()
  5. {
  6.   FILE *fp;
  7.   long get;
  8.   long i=0;
  9.   srand((unsigned)time(NULL));
  10.   fp = fopen("srand.txt","w");
  11.   for(i=0;i<1000000;i++)
  12.    {
  13.     get = rand();
  14.     fprintf(fp,"%d\n",get);
  15.     }
  16.    fclose(fp);
  17. }
复制代码


  1. #include<stdio.h>
  2. //void select_sort(unsigned int t,int n);
  3. main()
  4. {
  5.   int n=1000000;
  6.   unsigned int t;
  7.   char *s;
  8.   FILE *fp;
  9.   s = malloc(100);
  10.   fp = fopen("srand.txt","r");
  11.   while(!feof(fp))
  12.    {
  13.     fgets(s,100,fp);
  14.     t = atoi(s);
  15.     printf("%d\n",t);
  16. //    select_sort(t,n);
  17.    }
  18. free(s);
  19. fclose(fp);
  20. }
复制代码


不知道为什么,在这里就出毛病了,打印出来的数据被截去了一段。而且unsigned int t; 应该要定义为数组才能继续做后面的排序的。
我是刚开始学c,以前也没有实际的编程经验。现在卡在这里过不去了。所以请朋友们帮忙看看。我应该怎么改这段代码。

[ 本帖最后由 lovfreebsd 于 2007-11-9 16:52 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP