免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: 时间看来
打印 上一主题 下一主题

华为2011校园招聘上机题目(华南和成都)一组 第三题 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2012-05-29 18:41 |只看该作者
回复 9# cokeboL

为了便于调试,我增加了点输出语句:
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. void task_sort(int task[], int task_num, int max_task_num)
  4. {
  5.         int i, j;
  6.         int *count = (int*)malloc(sizeof(int)*max_task_num);

  7.         for(i=0; i<max_task_num; i++){
  8.                 count[i]=0;
  9.         }

  10.         for(i=0; i<task_num; i++){
  11.                 count[task[i]]++;
  12.         }

  13.         for(i=0, j=0; i<task_num; j++){
  14.                 while( (count[j]-- > 0) && i<task_num ){
  15.                         task[i++] = j;
  16.                 }
  17.         }

  18.         free(count);
  19. }

  20. void Scheduler(int task[], int task_num, int max_task_num, int system_task[], int user_task[])
  21. {
  22.         int i=0, n=0, j;
  23.         task_sort(task, task_num, max_task_num);
  24.         printf("task[]:\n");
  25.         for(j = 0; j < task_num; j++){
  26.                 printf("%d  ", task[j]);
  27.         }
  28.         printf("\n");

  29.         while(task[n]<50){
  30.                 system_task[n]=n++;
  31.         }
  32.         system_task[n]=-1;
  33.         printf("system_task:\n");
  34.         for(j = 0; j < task_num; j++){
  35.                 printf("%d  ", system_task[j]);
  36.         }
  37.         printf("\n");

  38.         while(task[n]<=255){
  39.                 user_task[i++]=n++;
  40.         }
  41.         user_task[n]=-1;
  42.         printf("user_task:\n");
  43.         for(j = 0; j < task_num; j++){
  44.                 printf("%d  ",user_task[j]);
  45.         }
  46.         printf("\n");
  47. }

  48. int main()
  49. {

  50.         int task[] = {0, 30, 155, 1, 80, 300, 170, 40, 99},
  51.                 system_task[20],
  52.                 user_task[20];
  53.         Scheduler(task, sizeof(task)/sizeof(int), 300, system_task, user_task);

  54.         return 0;
  55. }
复制代码
g++编译后,您程序的运行结果是:
task[]:
0  1  30  40  80  99  155  170  300  
system_task:
0  1  2  3  -1  104126944  -1075139896  13049472  -163754450  
user_task:
4  5  6  7  1  -1  2691008  103209324  -1  

gcc编译后输出是:
task[]:
0  1  30  40  80  99  155  170  300  
system_task:
0  1  2  3  -1  0  0  0  -163754450  
user_task:
4  5  6  7  1  0  0  0  -1  

说明,你排序后,改变了task[]的内容,再定位时,得到的位置数据是不正确的。
没弄明白7后面的1是怎么来的????但“user_task[n]=-1;”我想你的本意是“user_task=-1;”

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
12 [报告]
发表于 2012-05-29 20:13 |只看该作者
回复 10# lqfhvk357


    那有怎么样~

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
13 [报告]
发表于 2012-05-29 20:16 |只看该作者
回复 11# 时间看来


      
    写了没调试,49行的user_task[n]改成 user_task

    我比较懒惰,内核要管理进程根据时间来改变进程优先级,肯定要保存原来的顺序;
   
   但是这个题目没有,所以我就省去一步;
   
   如果要保持顺序,就加个key。

论坛徽章:
0
14 [报告]
发表于 2012-05-30 14:49 |只看该作者
  1. #include <stdio.h>

  2. void scheduler(const int task[], int n, int system_task[], int user_task[])
  3. {
  4.         int i, j, k, p, q;

  5.         p = q = 0;

  6.         for (i = 0; i < n; ++i)
  7.                 if (task[i] < 50) {
  8.                         for (j = 0; j < p && task[system_task[j]] < task[i]; ++j);
  9.                         for (k = p; k > j; --k)
  10.                                 system_task[k] = system_task[k - 1];
  11.                         system_task[j] = i;
  12.                         ++p;
  13.                 } else if (task[i] <= 255) {
  14.                         for (j = 0; j < q && task[user_task[j]] < task[i]; ++j);
  15.                         for (k = q; k > j; --k)
  16.                                 user_task[k] = user_task[k - 1];
  17.                         user_task[j] = i;
  18.                         ++q;
  19.                 }
  20.        
  21.         system_task[p] = user_task[q] = -1;
  22. }

  23. int main(void)
  24. {
  25.         int task[] = {0, 30, 155, 1, 80, 300, 170, 40, 99};
  26.         size_t n = sizeof(task) / sizeof(unsigned int);
  27.         int system_task[n], user_task[n], i;

  28.         scheduler(task, n, system_task, user_task);

  29.         for (i = 0; i < n; ++i)
  30.                 printf("%d ", task[i]);
  31.         printf("\n");

  32.         for (i = 0; system_task[i] != -1; ++i)
  33.                 printf("%d ", system_task[i]);
  34.         printf("%d\n", system_task[i]);

  35.         for (i = 0; user_task[i] != -1; ++i)
  36.                 printf("%d ", user_task[i]);
  37.         printf("%d\n", user_task[i]);

  38.         return 0;
  39. }
复制代码
调试用 gdb 就得了,不必printf

论坛徽章:
0
15 [报告]
发表于 2012-05-30 21:31 |只看该作者
回复 14# draytek58


嗯,用插入排序。
不过“for (j = 0; j < p && task[system_task[j]] < task; ++j);”,用<的话,相同优先级的进程会产生点小问题。把task[]里优先级相同的,且先出现的,排到了system_task[], user_task[]的后面去了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP