哪个大夫哪天值班
醫院有A、B、C、D、E、F、G七位大夫,在一星期內(星期一至星期天)每人要輪流值班一天。現在已知:
A大夫比C大夫晚一天值班;
D大夫比E大夫晚二天值班;
B大夫比G大夫早三天值班;
F大夫的值班日在B和C大夫的中間,且是星期四;
請確定每天究竟是哪位大夫值班?
*問題分析與算法設計
由題目可推出如下已知條件:
*F是星期四值班;
*B值班的日期在星期一至星期三,且三天后是G值班;
*C值班的日期在星期五至星期六,且一天后是A值班;
*E兩天后是D值班;E值班的日期只能在星期一至星期三;
在編程時用數組元素的下標1到7表示星期一到星期天,用數組元素的值分別表示A~F七位大夫。
*程序說明與注釋
#include<stdio.h>
#include<stdlib.h>
int a[8];
char *day[]={"","MONDAY","TUESDAY","WEDNESDAY","THURSDAYT",
"FRIDAY","SATUDAY","SUNDAY"}; /*建 立星期表*/
int main()
{
int i,j,t;
a[4]=6; /*星期四是F值班*/
for(i=1;i<=3;i++)
{
a[i]=2; /*假設B值班的日期*/
if(!a[i+3]) a[i+3]=7; /*若三天后無人值班則安排G值班*/
else{ a[i]=0;continue;} /*否則B值班的日期不斷對*/
for(t=1;t<=3;t++) /*假設E值班的時間*/
{
if(!a[t]) a[t]=5; /*若當天無人值班則安排E值班*/
else continue;
if(!a[t+2]) a[t+2]=4; /*若E值班兩天后無人值班則應為D*/
else{ a[t]=0;continue;} /*否則E值班的日期不對*/
for(j=5;j<7;j++)
{
if(!a[j]) a[j]=3; /*若當天無人值班,則安排C值班*/
else continue;
if(!a[j+1]) a[j+1]=1; /*C之后一天無人值班則應當是A值班*/
else{ a[j]=0;continue;} /*否則A值班日期不對*/
for(i=1;i<=7;i++) /*安排完畢,輸出結果*/
printf("Doctor %c is on duty %s.\n",'A'+a[i]-1,day[i]);
exit(0);
}
}
}
}
*運行結果
Doctor E is on duty MONDAY. (星期一:E)
Doctor B is on duty TUESDAY. (星期二:B)
Doctor D is on duty WEDNESDAY. (星期三:D)
Doctor F is on duty THUESDAY. (星期四:F)
Doctor G is on duty FRIDAY. (星期五:G)
Doctor C is on duty SATURDAY. (星期六:C)
Doctor A is on duty SUNDAY. (星期日:A)
*思考題
在本題的求解過程中,我們只考慮了一星期之內的情況,沒有考慮跨周的情況。對于“B大夫比G大夫早三天值班的”條件只是簡單的認為是在同一周內早三天。若考慮跨周的情況就可能出現:B大夫星期一值班,而G大夫是上周的星期五。同樣,對“F大夫的值班日在B和C大夫的中間”這個條件,也可以擴展為:“只要F大夫的值班日在B和C大夫的中間就可以”。
請考慮允許跨周的情況下,可能的時間安排表。
轉載于:https://www.cnblogs.com/junzhongxu/archive/2008/07/31/1257006.html
總結
- 上一篇: 在Word中插入条形码又一法
- 下一篇: vs2005常用调试快捷键 (转载)