试题四 (一个DFS题,看懂题意就可以做出来)
 /**//*
[说明]
假设需要将N个任务分配给N个工人同时去完成,每个人都能承担这N个任务,
但费用不同。下面的程序用回溯法计算总费用最小的一种工作分配方案,在该方案中,
为每个人分配1个不同的任务。
程序中,N个任务从0开始依次编号,N个工人也从0开始依次编号,主要的变量说明如下:
c[i][j]:将任务i分配给工人 j的费用;
task[i]:值为0表示任务i未分配。值为j表示任务i分配给工人j;
worker[k]:值为0表示工人k未分配任务,值为1表示工人k已分配任务;
mincost:最小总费用。
[C程序]
*/
#include <iostream>
#define N 4 /*N表示任务数和工人数*/
int c[N][N];
 unsigned int mincost = 65535; /**//*设置min的初始值,大于可能的总费用*/
int task[N],temp[N],worker[N];
void plan(int k,unsigned int cost)
  { int i;
//if(_____(1)_____&& cost < mincost)
if(k==N && cost<mincost)
 {
mincost = cost;
for (i=0;i<N;i++) temp[i]=task[i];
}
else
 {
 for ( i = 0 ; i<N; i ++ ) /**//*分配任务k*/
if(worker[i]==0 && cost+c[k][i]<mincost)
//if ( worker [i]==0 && ___(2)_____) //
 {
//worker[i] = 1;task[k]=___(3)_____;//i
//plan(_____(4)_____,cost+c[k][i]);//k+1
//______(5)_______; task [k] = 0;//worker[i]=0
worker[i]=1;task[k]=i;
plan(k+1,cost+c[k][i]);
worker[i]=0;
task[k]=0;
 } /**//*if*/
}
 } /**//*Plan*/

int main ()
  { int i,j;
freopen("in.cpp","r",stdin);
for(i = 0;i < N;i ++)
  { /**//*设置每个任务由不同工人承担时的费用及全局数组的初值*/
worker [ i ] = 0; task [ i ] = 0; temp [ i ] = 0;
for ( j = 0 ; j < N ; j ++)
scanf ("%d",&c[ i ] [ j ]);
}
 plan (0,0); /**//*从任务0开始分配*/
printf("\n最小费用 = %d\n",mincost);
for (i = 0; i < N; i ++)
printf ("Task%d is assigned to Worker%d\n",i,temp[ i ]);
return 0;
 }/**//*main*/
试题五
#include <iostream>
//[代码5-1]
 class Circle : public___(1)____ { //Shape
private:
_______(2)________m_circle; //XCircle
public:
 void display() {
m_circle._____(3)_____;//displayIt()
}
};

//[代码5-2]
 class Factory {
public :
 _____(4)_____getShapeInstance(int type) { //生成特定类实例
//Shape *
 switch (type) {
case 0: return new point;
case 1: return new Rectangle;
case 2: return new line;
case 3: return new Circle;
default: return NULL;
}
}
};
 void main (int argc , char *argv[]) {
 if (argc ! =2) {
cout << “error parameters !”<<endl;
return;
}
int type = atoi (argv[ l ]);
Factory factory;
Shape *s;
s = factory._____(5)____;//getShapeInstance(type)
 if (s ==NULL) {
cout <<”Error get the instance !” << endl;
return;
}
c->display();
__(6)___; //delete s
return;
}
第6空没注意,想了半天 ...~
|
|
随笔:5
文章:28
评论:1
引用:0
| 日 | 一 | 二 | 三 | 四 | 五 | 六 |
---|
26 | 27 | 28 | 29 | 30 | 31 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |
|
公告
Blog里的内容如果没有注明为转载,就是原创文章,需要转载的朋友请注明出处。文章中如有错误,请指出。转载内容如果有侵权行为,请与我联系,----issac_asimoy@qq.com。
常用链接
留言簿(1)
随笔分类(5)
随笔档案(5)
文章分类(28)
文章档案(28)
相册
My World
Study Web
最新随笔
搜索
积分与排名
最新评论

阅读排行榜
评论排行榜
|
|