早教吧 育儿知识 作业答案 考试题库 百科 知识分享
早教吧考试题库频道 --> 计算机类考试 -->软考中级 -->

试题四(共15分)阅读下列说明和C代码,回答问题1至问题3,将解答写在答题纸的对应栏内。【说明】用两台

题目

试题四(共15分)

阅读下列说明和C代码,回答问题1至问题3,将解答写在答题纸的对应栏内。

【说明】

用两台处理机A和B处理n个作业。设A和B处理第i个作业的时间分别为ai和bi。由于各个作业的特点和机器性能的关系,对某些作业,在A上处理时间长,而对某些作业在B上处理时间长。一台处理机在某个时刻只能处理一个作业,而且作业处理是不可中断的,每个作业只能被处理一次。现要找出一个最优调度方案,使得n个作业被这两台处理机处理完毕的时间(所有作业被处理的时间之和)最少。

算法步骤:

(1)确定候选解上界为R短的单台处理机处理所有作业的完成时间m,

(2)用p(x,y,k)=1表示前k个作业可以在A用时不超过x且在B用时不超过y时间 内处理完成,则p(x,y,k)=p(x-ak,y,k-1)||p(x,y-bk,k-1)(||表示逻辑或操作)。

(3)得到最短处理时问为min(max(x,y))。

【C代码】

下面是该算法的C语言实现。

(1)常量和变量说明

n: 作业数

m: 候选解上界

a: 数组,长度为n,记录n个作业在A上的处理时间,下标从0开始

b: 数组,长度为n,记录n个作业在B上的处理时间,下标从0开始

k: 循环变量

p: 三维数组,长度为(m+1)*(m+1)*(n+1)

temp: 临时变量

max: 最短处理时间

(2)C代码

include<stdio.h>

int n, m;

int a[60], b[60], p[100][100][60];

void read(){ /*输入n、a、b,求出m,代码略*/}

void schedule(){ /*求解过程*/

int x,y,k;

for(x=0;x<=m;x++){

for(y=0;y<m;y++){

(1)

for(k=1;k<n;k++)

p[x][y][k]=0;

}

}

for(k=1;k<n;k++){

for(x=0;x<=m;x++){

for(y=0;y<=m;y++){

if(x - a[k-1]>=0) (2) ;

if( (3) )p[x][y][k]=(p[x][y][k] ||p[x][y-b[k-1]][k-1]);

}

}

}

}

void write(){ /*确定最优解并输出*/

int x,y,temp,max=m;

for(x=0;x<=m;x++){

for(y=0;y<=m;y++){

if( (4) ){

temp=(5) ;

if(temp< max)max = temp;

}

}

}

printf("\n%d\n",max),

}

void main(){read();schedule();write();}

【问题1】 (9分)

根据以上说明和C代码,填充C代码中的空(1)~(5)。

【问题2】(2分)

根据以上C代码,算法的时间复杂度为(6)(用O符号表示)。

【问题3】(4分)

考虑6个作业的实例,各个作业在两台处理机上的处理时间如表4-1所示。该实例的最优解为(7),最优解的值(即最短处理时间)为(8)。最优解用(x1,x2,x3,x4,x5,x6)表示,其中若第i个作业在A上赴理,则xi=l,否则xi=2。如(1,1,1,1,2,2)表示作业1,2,3和4在A上处理,作业5和6在B上处理。

参考答案
正确答案:
【问题1)(9分)
(1)p[x][y][0]=1
(2)p[x][y][k]=p[x-a[k-1]][y][k-1]
(3)y- b[k-1]>=0
(4) p[x][y][n]==1或p[x][y][n]或p[x][y][n]!=0
(5)(x>=y)?x:y
【问题2】
(6) O(m2n)
【问题3】(4分)
(7)(1,1,2,2,1,1)
(8)15
看了试题四(共15分)阅读下列说明...的网友还看了以下:

9.有一种二十四点的游戏,其游戏规则是这样的:任取四个1至13之间的自然数,将这四个数(每个数只能 数学 2020-04-27 …

语出自《中庸》二十四章:至诚之道可以前知.国家将兴,必有祯祥;国家将亡,必有妖孽.见乎蓍龟,动乎四 历史 2020-05-13 …

有一种二十四点游戏,规则是:取四个1至13之间的自然数,将这四个数(每个用一次)进行加减乘除运算, 数学 2020-05-20 …

试题四:阅读下列说明,回答问题1至问题4,将解答填入答题纸的对应栏内。【说明】某系统集成公司项目经 计算机类考试 2020-05-26 …

有一种“二十四点”的游戏,其游戏规则是这样的:任取四个1至13之间的自然数,将这四个数(每个数用且 其他 2020-06-04 …

辙幼从子瞻读书,未尝一日相舍,既仕,将游宦四方,读书苏州诗,诗至,‘安知风雨夜,复此对床眠.’恻然 语文 2020-07-02 …

说明文阅读题《冬至》冬至作为我国最古老的四个节气之一,早在两千五百多年前的春秋时代,古人就已经用土 其他 2020-07-04 …

有一种"二十四点"的游戏,其游戏规则是这样的:任取四个1至13之间的自然数,将这四个数有一种“二十 数学 2020-07-17 …

为了测量桥的高度,在桥上将绳子四折垂至水面,尚余3米,把绳子剪去6米.为了测量桥的高度,在桥上将绳 数学 2020-07-20 …

欲将轻骑逐的“将”读第几声欲将轻骑逐的“将”读第几声个人认为读第四声,率领的意思,但《古诗80首》上 其他 2020-12-03 …