码迷,mamicode.com
首页 > 编程语言 > 详细

c++实现医院检验科排班程序

时间:2015-06-06 19:39:07      阅读:212      评论:0      收藏:0      [点我收藏+]

标签:c++ 排班 程序 需求 实现 源码


c++实现医院检验科排班程序

1、背景:
医院急诊检验科24h×7×365值班,工作人员固定。采取轮班制度,确保24h都有人值班。
本文就通过C++实现编写程序自动排班,并可以转为Excel打印。

2、急诊检验科排班概况(口头咨询后整理):
1)、检验科人数:7人。
2)、上班类型:"夜班", "起夜", "休息", "急诊", "急值", "急诊午",共5种。
3)、上班时间:每人固定每周休息2天,但两天为一周内的任意两天。
4)、谁来排班:主任负责排班。
5)、排班原则:新同事1人,不上夜班。新同事每周上班类型完全一致。
                          主任每周上班类型也不变。
                           除新同事和主任外的其他同事,采取轮班制。
6)、轮班原则:除主任和新同事外的四位同事上班逐周上班类型为:ABCD,BCDA,CDAB,DABC,ABCD....依次轮询,每周变化一次....

3、细化需求:
1)实现自动排班程序。
2)输入:年份如2015,以及一个月的基准排班表(检验科提供)。
3)输出:1年的排班表,以周为单位,包含:当前年第几周,星期几,日期,检验师名称,排班表。
     输出形式:控制台、txt文档、Excel文档(可以用来打印)。

4、自我分析:
1)由于排班存在规律性,所以可以通过程序实现。
2)以周为单位实现,只需要将年份的天数统计存储下来,如2015年365天,然后逐周7天为单位打印即可。
3)Excel本身支持txt文档,只需要输出规范的txt文档,导入Excel即满足需求。

5、程序运行截图:
技术分享

6、源码实现(VS2010实现):

// workOrderDemo.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include <iostream>
using namespace std;
#include <stdio.h>
#include <stdlib.h>
#include <iomanip>
#include <assert.h>
#include <vector>
#include <fstream>
#include <assert.h>
#define EQUAL '='
#define SPACE ' '
#define STARBAR '*'
typedef unsigned int UINT32;
#define MAX_NAME_LEN 100   //最大名字长度
#define MAX_SPAN_LEN 9    //间隔字符长度
#define MAX_WEEKS_CNT 52   //365/7 或者366/7 周数
#define MAX_CYC_WEEK_CNT 6   //最大循环次数
#define MAX_MONTH_CNTS_IN_YEAR 12   //1年的月份数
#define THIS_YEAR 2015              //当前的年份
const char* pszOutFile = "E:\\WorkTable.txt";
ofstream g_fOutFile(pszOutFile); //打开文件用于写,若文件不存在就创建它
//星期序列
typedef enum WEEK_DAY
{
MONDAY = 0,
TUESDAY,
WEDNESDAY,
THURSDAY,
FRIDAY,
SATUDAY,
SUNDAY,
MAX_WORK_DAYS //计数用
}WEEKDAY;
//值班检验师名称
typedef enum INSPECTOR_YANTAI
{
WANG_XIN_PING = 0,
FU_TIAN = 1,
ZHAO_JI_JUAN = 2, //0
ZHAO_YU_XIANG,
ZHANG_XIA,
WANG_XIAO_FEI,
ZHU_HONG_JING,
MAX_INSPECTOR_CNT  //计数用
}INSPECTOR;
//值班类型
typedef enum WORK_TYPES
{
NIGHT_WORK = 0,   //夜班
AFTER_NIGHT_WORK, //起夜
SLEEP,            //休息
URGENT_DIAGNOSE,  //急诊
URGENT_WORK,      //急值
URGENT_DIAGNOSE_AFTERNON, //急诊午
WORK_CNTS                 //7 计数用
}WORK_TYPE;

char g_pszInspectorArr[MAX_INSPECTOR_CNT][MAX_NAME_LEN] = {"王*平", "付*明", "赵*娟", "赵*香", "张*玉", "王*飞", "朱*静"};
char g_workTypeName[WORK_CNTS][MAX_NAME_LEN] = {"夜班", "起夜", "休息", "急诊", "急值", "急诊午" };
char g_weekDayName[MAX_WORK_DAYS][MAX_NAME_LEN] = {"周一", "周二", "周三", "周四", "周五", "周六", "周日"};
//临时存储
WORK_TYPE g_TmpDayWork[MAX_WORK_DAYS] = {NIGHT_WORK};
WORK_TYPE g_WeekWorkTable[MAX_INSPECTOR_CNT][MAX_WORK_DAYS] = {NIGHT_WORK};
WORK_TYPE g_WeekWorkTableBak[MAX_INSPECTOR_CNT][MAX_WORK_DAYS] = {NIGHT_WORK};  //基准表,1月份的永恒不变

//存储格式化日期格式
vector<char* > g_DaysVector;

/*
**@brief:打印字符格式化用
**@param:ch字符, num个数
**@return:空.
*/  
void print_n_char(char ch , int num)
{
int count = 0;
for (count = 0 ; count < num ; count++)
{
  cout << ch;
  g_fOutFile << SPACE;
}
}
/*
**@brief:根据年月日返回星期几
**@param:UINT32 iYear 年, UINT32 iMonth 月, UINT32 iDay 日
**@return: 星期几.
*/  
int ReturnWeekDay(UINT32 iYear, UINT32 iMonth, UINT32 iDay)
{
int iWeek = 0;
UINT32 y = 0, c = 0, m = 0, d = 0;
if ( iMonth == 1 || iMonth == 2 )
{
  c = ( iYear - 1 ) / 100;
  y = ( iYear - 1 ) % 100;
  m = iMonth + 12;
  d = iDay;
}
else
{
  c = iYear / 100;
  y = iYear % 100;
  m = iMonth;
  d = iDay;
}
iWeek = y + y / 4 + c / 4 - 2 * c + 26 * ( m + 1 ) / 10 + d - 1;    //蔡勒公式
iWeek = iWeek >= 0 ? ( iWeek % 7 ) : ( iWeek % 7 + 7 );    //iWeek为负时取模
if ( iWeek == 0 )    //星期日不作为一周的第一天
{
  iWeek = 7;
}
return iWeek;
}
/*
**@brief:返回格式化周几
**@param:int iWeekDay 星期几
**@return: 格式化周几.
*/  
char* GetWeekName(int iWeekDay)
{
assert(iWeekDay > 0);
return g_weekDayName[iWeekDay - 1];
}
/*
**@brief:初始化基准工作表,以5月11号一周为基准(设定为1月1日)
**@param:空
**@return:无
*/  
void InitWorkTableBakFun()
{
//0 WANG_XIN_PING
g_WeekWorkTableBak[WANG_XIN_PING][MONDAY] = URGENT_DIAGNOSE;
g_WeekWorkTableBak[WANG_XIN_PING][TUESDAY] = URGENT_WORK;
g_WeekWorkTableBak[WANG_XIN_PING][WEDNESDAY] = URGENT_DIAGNOSE_AFTERNON;
g_WeekWorkTableBak[WANG_XIN_PING][THURSDAY] = NIGHT_WORK;
g_WeekWorkTableBak[WANG_XIN_PING][FRIDAY] = AFTER_NIGHT_WORK;
g_WeekWorkTableBak[WANG_XIN_PING][SATUDAY] = SLEEP;
g_WeekWorkTableBak[WANG_XIN_PING][SUNDAY] = SLEEP;
//1 FU_TIAN
g_WeekWorkTableBak[FU_TIAN][MONDAY] = URGENT_DIAGNOSE_AFTERNON;
g_WeekWorkTableBak[FU_TIAN][TUESDAY] = URGENT_DIAGNOSE;
g_WeekWorkTableBak[FU_TIAN][WEDNESDAY] = SLEEP;
g_WeekWorkTableBak[FU_TIAN][THURSDAY] = URGENT_DIAGNOSE;
g_WeekWorkTableBak[FU_TIAN][FRIDAY] = URGENT_DIAGNOSE;
g_WeekWorkTableBak[FU_TIAN][SATUDAY] = SLEEP;
g_WeekWorkTableBak[FU_TIAN][SUNDAY] = URGENT_DIAGNOSE;
//2 ZHAO_JI_JUAN
g_WeekWorkTableBak[ZHAO_JI_JUAN][MONDAY] = NIGHT_WORK;
g_WeekWorkTableBak[ZHAO_JI_JUAN][TUESDAY] = AFTER_NIGHT_WORK;
g_WeekWorkTableBak[ZHAO_JI_JUAN][WEDNESDAY] = SLEEP;
g_WeekWorkTableBak[ZHAO_JI_JUAN][THURSDAY] = SLEEP;
g_WeekWorkTableBak[ZHAO_JI_JUAN][FRIDAY] = AFTER_NIGHT_WORK;
g_WeekWorkTableBak[ZHAO_JI_JUAN][SATUDAY] = URGENT_DIAGNOSE;
g_WeekWorkTableBak[ZHAO_JI_JUAN][SUNDAY] = NIGHT_WORK;
//3 ZHAO_YU_XIANG
g_WeekWorkTableBak[ZHAO_YU_XIANG][MONDAY] = URGENT_WORK;
g_WeekWorkTableBak[ZHAO_YU_XIANG][TUESDAY] = NIGHT_WORK;
g_WeekWorkTableBak[ZHAO_YU_XIANG][WEDNESDAY] = AFTER_NIGHT_WORK;
g_WeekWorkTableBak[ZHAO_YU_XIANG][THURSDAY] = SLEEP;
g_WeekWorkTableBak[ZHAO_YU_XIANG][FRIDAY] = URGENT_WORK;
g_WeekWorkTableBak[ZHAO_YU_XIANG][SATUDAY] = URGENT_DIAGNOSE_AFTERNON;
g_WeekWorkTableBak[ZHAO_YU_XIANG][SUNDAY] = SLEEP;
//4 ZHANG_XIA
g_WeekWorkTableBak[ZHANG_XIA][MONDAY] = SLEEP;
g_WeekWorkTableBak[ZHANG_XIA][TUESDAY] = URGENT_DIAGNOSE_AFTERNON;
g_WeekWorkTableBak[ZHANG_XIA][WEDNESDAY] = NIGHT_WORK;
g_WeekWorkTableBak[ZHANG_XIA][THURSDAY] = AFTER_NIGHT_WORK;
g_WeekWorkTableBak[ZHANG_XIA][FRIDAY] = SLEEP;
g_WeekWorkTableBak[ZHANG_XIA][SATUDAY] = URGENT_WORK;
g_WeekWorkTableBak[ZHANG_XIA][SUNDAY] = URGENT_WORK;

//5 WANG_XIAO_FEI
g_WeekWorkTableBak[WANG_XIAO_FEI][MONDAY] = SLEEP;
g_WeekWorkTableBak[WANG_XIAO_FEI][TUESDAY] = SLEEP;
g_WeekWorkTableBak[WANG_XIAO_FEI][WEDNESDAY] = URGENT_WORK;
g_WeekWorkTableBak[WANG_XIAO_FEI][THURSDAY] = URGENT_DIAGNOSE_AFTERNON;
g_WeekWorkTableBak[WANG_XIAO_FEI][FRIDAY] = NIGHT_WORK;
g_WeekWorkTableBak[WANG_XIAO_FEI][SATUDAY] = AFTER_NIGHT_WORK;
g_WeekWorkTableBak[WANG_XIAO_FEI][SUNDAY] = URGENT_DIAGNOSE_AFTERNON;
//6 ZHU_HONG_JING
g_WeekWorkTableBak[ZHU_HONG_JING][MONDAY] = SLEEP;
g_WeekWorkTableBak[ZHU_HONG_JING][TUESDAY] = SLEEP;
g_WeekWorkTableBak[ZHU_HONG_JING][WEDNESDAY] = URGENT_DIAGNOSE;
g_WeekWorkTableBak[ZHU_HONG_JING][THURSDAY] = URGENT_WORK;
g_WeekWorkTableBak[ZHU_HONG_JING][FRIDAY] = URGENT_DIAGNOSE_AFTERNON;
g_WeekWorkTableBak[ZHU_HONG_JING][SATUDAY] = NIGHT_WORK;
g_WeekWorkTableBak[ZHU_HONG_JING][SUNDAY] = AFTER_NIGHT_WORK;

}
/* 
**@brief:判定年份是否为闰年.
**@param: iYear当前年份.
**@return:true,闰年; false,平年.
*/  
bool IsLeapYear(UINT32 iYear)  
{  
if ( (iYear%4 == 0 && iYear%100 != 0) || (iYear%400 == 0) )  
{  
  return true;  
}  
else  
{  
  return false;  
}  
}
/*
**@brief:初始化工作表(与基准表一致)
**@param:空
**@return:无
*/  
void InitWorkTableFun()
{
//与基准对齐
for (int inspector = 0; inspector < MAX_INSPECTOR_CNT; ++inspector)
{
  for (int curDay = 0; curDay < MAX_WORK_DAYS; ++curDay)
  {
   g_WeekWorkTable[inspector][curDay] = g_WeekWorkTableBak[inspector][curDay];
  }
}
}
/*
**@brief: 返回vector数组中的起始位置,打印用
**@param: nCurWeek 当前第几周
**@return:返回pos
*/  
int GetBeginOfDaysVector(UINT32 nCurWeek)
{
//获取第几周的日期格式
//如第一周返回:1月1, 1月2, ... 1月7
assert(nCurWeek >= 0 && nCurWeek <= 1 + MAX_WEEKS_CNT);
int iBegin = (nCurWeek - 1) * 7;
return iBegin;
}
/*
**@brief: 打印对应周的排班表
**@param: iWeek 当前第几周
**@return:无
*/  
void PrintCurWorkTable(int iWeek)
{
char szTmpFormat[MAX_NAME_LEN] = {0};
for (int curDay = 0; curDay < 1 + MAX_WORK_DAYS; ++curDay)
{
  if (0 == curDay)
  {
   cout << std::right << std::setw(MAX_SPAN_LEN) << "";
   g_fOutFile << std::right << std::setw(MAX_SPAN_LEN) << "";
  }
  else
  {
   cout << std::right << std::setw(MAX_SPAN_LEN) << g_weekDayName[curDay - 1];
   g_fOutFile << std::right << std::setw(MAX_SPAN_LEN) << g_weekDayName[curDay - 1];
  }
}
cout << endl;
g_fOutFile << endl;
int nDaysOfYear = 0;
//打印日期第几周 格式:1-1
int iBegin = 0;
int iWeekLen = 7;
if (iWeek <= MAX_WEEKS_CNT)
{
  iBegin = GetBeginOfDaysVector(iWeek);
  cout << std::right << std::setw(MAX_SPAN_LEN) << "";
  g_fOutFile << std::right << std::setw(MAX_SPAN_LEN) << "";
  for (int i = iBegin; i < iBegin + iWeekLen; ++i)
  {
   cout << std::right << std::setw(MAX_SPAN_LEN) << g_DaysVector[i];
   g_fOutFile << std::right << std::setw(MAX_SPAN_LEN) << g_DaysVector[i];
  }
  cout << endl;
  g_fOutFile << endl;
}
else
{
  if (IsLeapYear(THIS_YEAR))
  {
   nDaysOfYear = 366;
  }
  else
  {
   nDaysOfYear = 365;
  }
  //最后一周单独处理
  iWeekLen = nDaysOfYear - (MAX_WEEKS_CNT)*7;
  iBegin = GetBeginOfDaysVector(1 + MAX_WEEKS_CNT);
  for (int i = iBegin; i < iBegin + iWeekLen; ++i)
  {
   cout << std::right << std::setw(MAX_SPAN_LEN) << g_DaysVector[i];
   g_fOutFile << std::right << std::setw(MAX_SPAN_LEN) << g_DaysVector[i];
  }
  cout << endl;
  g_fOutFile << endl;
}

for (int curDay = 0; curDay < 1 + MAX_WORK_DAYS; ++curDay)
{
  if (0 == curDay)
  {
   cout << std::right << std::setw(MAX_SPAN_LEN) << "";
   //g_fOutFile << std::right << std::setw(MAX_SPAN_LEN) << "";
  }
  for (int j = 0; j < MAX_SPAN_LEN - 1; ++j)
  {
   cout << '-';
   //g_fOutFile << ' ';
  }
}
cout << endl;
//g_fOutFile << endl;

int curWorkType  = 0;
for (int inspector = 0; inspector < MAX_INSPECTOR_CNT; ++inspector)
{
  sprintf_s(szTmpFormat , "%d%s", inspector, g_pszInspectorArr[inspector]);
  cout << std::left << std::setw(MAX_SPAN_LEN) << szTmpFormat;
  g_fOutFile << std::right << std::setw(MAX_SPAN_LEN) << szTmpFormat;
  for (int curDay = 0; curDay < MAX_WORK_DAYS; ++curDay)
  {
   curWorkType = (int)(g_WeekWorkTable[inspector][curDay]);
   cout << std::right << std::setw(MAX_SPAN_LEN)<< g_workTypeName[curWorkType];
   g_fOutFile << std::right << std::setw(MAX_SPAN_LEN)<< g_workTypeName[curWorkType];
  }
  cout << endl;
  g_fOutFile << endl;
}
}
/*
**@brief: 测试打印日期格式
**@param: 空
**@return:无
*/  
void testWeekDayOfData()
{
int iYear = 2015;
int iMonth = 6;
int iDay = 1;
for (iDay = 1; iDay <= 30; ++iDay)
{
  int iWeekDay = ReturnWeekDay(iYear, iMonth, iDay);
  cout << iWeekDay << GetWeekName(iWeekDay) << "\t";
  if (iDay % 7 == 0)
  {
   cout << endl;
  }
}
}

/*
**@brief: 以基准周为依据按照规律排班
**@param: nWeek当前第几周
**@return:无
*/  
void ExchangeWork(UINT32 nWeek)
{
assert(nWeek >= 0 && nWeek <= MAX_INSPECTOR_CNT - 2);  //0-5之间
//0 第1周不变:   排班顺序 0 1 2 3 4 5 6;
//1 第2周:       排班顺序 0 1 3 4 5 6 2;
//2 第3周:       排班顺序 0 1 4 5 6 2 3;
//3 第4周:       排班顺序 0 1 5 6 2 3 4;
//4 第5周:       排班顺序 0 1 6 2 3 4 5; 循环终止
//5 第6周:       排班顺序 0 1 2 3 4 5 6; 同第一周
//每次都从基准周变更
if (0 == nWeek)
{
  (void)InitWorkTableFun();
}
else
{
  (void)InitWorkTableFun();
   //1-6 6个人,第0行始终不变无需再排班
  for (int iInspector = 2; iInspector < MAX_INSPECTOR_CNT ; ++iInspector) 
  {
   int iNewOrder = iInspector + nWeek;
   if (iNewOrder > (MAX_INSPECTOR_CNT - 1))
   {
    iNewOrder = (iInspector + nWeek) % (MAX_INSPECTOR_CNT - 2);
   }

   if (0 == iNewOrder)
   {
    iNewOrder = 5;
   }
   //cout << "iNewOrder = " << iNewOrder << endl;
   assert(iNewOrder == 3 || iNewOrder == 4 || iNewOrder == 5 || iNewOrder == 6 || iNewOrder == 2);
   //周一到周日
   for (int curDay = 0; curDay < MAX_WORK_DAYS; ++curDay) //0-6 7天
   {
    
    if (2 == iInspector)
    {
     g_TmpDayWork[curDay] = g_WeekWorkTable[nWeek][curDay];  //
    }
    g_WeekWorkTable[iInspector][curDay] = g_WeekWorkTableBak[iNewOrder][curDay];

   }//end for curDay
  }//end for iInspector
}//end else
}
/*
**@brief: 全年中第几周的排班表
**@param: nWeek当前全年的第几周
**@return:无
*/  
void CurWeekWorkOrder(UINT32 nWeek)
{
assert(nWeek <= MAX_WEEKS_CNT);

//全年周转化为规律周
UINT32 nOrderWeek = nWeek % (MAX_INSPECTOR_CNT - 2);
assert(nOrderWeek >= 0 && nOrderWeek < (MAX_INSPECTOR_CNT - 2));
//cout << "nWeek = " << nWeek << "nOrderWeek = " << nOrderWeek << endl;
(void)ExchangeWork(nOrderWeek);
}
/* 
**@brief:判定某年某月的天数.
**@param: iYear当前年份,iMonth当前月份;
**@return:当前年、月的天数.
*/  
unsigned int daysInMonth(UINT32 nYear, UINT32 nMonth)  
{  
assert(nMonth >=1 && nMonth <= MAX_MONTH_CNTS_IN_YEAR);  
int nDaysInMonth = 0;  
switch(nMonth)  
{  
case 1:  
case 3:  
case 5:  
case 7:  
case 8:  
case 10:  
case 12:  
  nDaysInMonth = 31;  
  break;  
case 4:  
case 6:  
case 9:  
case 11:  
  nDaysInMonth = 30;  
  break;  
case 2:  
  if (IsLeapYear(nYear))  
  {  
   nDaysInMonth = 29;  
  }  
  else  
  {  
   nDaysInMonth = 28;  
  }  
  break;  
default:  
  cout << "Error Month!!" << endl;  
  break;  
}  
return nDaysInMonth;  
}
/* 
**@brief:构建格式化日期
**@param: nYear 当年年份
**@return:无
*/  
void BuildDayOfMonth(UINT32 nYear)
{
UINT32 nDaysOfYear = 0;
if (IsLeapYear(nYear))
{
  nDaysOfYear = 366;
}
else
{
  nDaysOfYear = 365;
}

for (int iMonth = 1; iMonth <= MAX_MONTH_CNTS_IN_YEAR; ++iMonth)
{
  for (int iDay = 1; iDay <= (int)(daysInMonth(nYear, iMonth)); ++iDay)
  { 
   char *pszDataFormat = (char*)malloc(20);
   memset(pszDataFormat, 0, 20);
   sprintf_s(pszDataFormat, 20, "%d月%d日", iMonth, iDay);
   //cout << pszDataFormat << "\t";
   g_DaysVector.push_back(pszDataFormat);
  }//end for iDay
  //cout << endl;
}//end for iMonth
}
/* 
**@brief:释放内存
**@param: 空
**@return:无
*/  
void ReleaseDaysVector()
{
int iVectorSize = g_DaysVector.size();
//cout << "iVectorSize = " << iVectorSize << endl;
for (int i = 0; i < iVectorSize; ++i)
{
  if (NULL != g_DaysVector[i])
  {
   free(g_DaysVector[i]);
   g_DaysVector[i] = NULL;
  }
}
}
/* 
**@brief:测试打印全年日期格式
**@param: 当前年份
**@return:无
*/  
void testPrintDaysByWeek(UINT32 nYear)
{
int iWeekLen = 7;  //每周七天
int nDaysOfYear = 0;
if (IsLeapYear(nYear))
{
  nDaysOfYear = 366;
}
else
{
  nDaysOfYear = 365;
}
cout << endl;
int iBegin  = 0;
for (int iWeek = 1; iWeek <= MAX_WEEKS_CNT; ++iWeek)
{
  iBegin = GetBeginOfDaysVector(iWeek);
  for (int i = iBegin; i < iBegin + iWeekLen; ++i)
  {
   cout << g_DaysVector[i] << "\t";
  }
  cout << endl;
}
//最后一周单独处理
iWeekLen = nDaysOfYear - (MAX_WEEKS_CNT)*7;
iBegin = GetBeginOfDaysVector(1 + MAX_WEEKS_CNT);
for (int i = iBegin; i < iBegin + iWeekLen; ++i)
{
  cout << g_DaysVector[i] << "\t";
}
cout << endl;
}
void testPrintVectorDays()
{
int iVectorSize = g_DaysVector.size();
//cout << "iVectorSize = " << iVectorSize << endl;
for (int i = 0; i < iVectorSize; ++i)
{
  cout << g_DaysVector[i] << "\t";
}

}
int _tmain(int argc, _TCHAR* argv[])
{
(void)InitWorkTableBakFun();  //基准初始化
(void)BuildDayOfMonth(THIS_YEAR);
//(void)testPrintDaysByWeek(THIS_YEAR);
//初始化写文件
if (!g_fOutFile)
{
  cout << "Open file" << pszOutFile << "Failed!" << endl;
}
char szDateFormat[128] = {0};
//打印全年排班表
for(int iWeek = 1; iWeek <= MAX_WEEKS_CNT; ++iWeek)
{
  print_n_char(STARBAR, 28);
  sprintf_s(szDateFormat, " %d 年 第 %d 周", THIS_YEAR, iWeek);
  cout << szDateFormat;
  g_fOutFile << szDateFormat;
  print_n_char(STARBAR, 28);
  cout << endl;
  g_fOutFile << endl;
  //逐月份排班
  (void)CurWeekWorkOrder(iWeek - 1);
  (void)PrintCurWorkTable(iWeek);
   cout << endl << endl;
   g_fOutFile << endl << endl;
}
(void)ReleaseDaysVector();
g_fOutFile.close();
getchar();
return 0;
}


7、结束语
1)该类问题相对简单,实现中细节的逻辑比较复杂,在纸上模拟把程序多跑几遍,理顺逻辑很重要。
2)规律是突破口,其他都是辅助完成。
3)反复测试,对每个接口对写对应Demo测试接口。

2015-6-6  pm18:09 思于家中床前,耗时9h

作者:铭毅天下

转载请标明出处,原文地址:http://blog.csdn.net/laoyang360/article/details/46390293

如果感觉本文对您有帮助,请点击‘顶’支持一下,您的支持是我坚持写作最大的动力,谢谢!


c++实现医院检验科排班程序

标签:c++ 排班 程序 需求 实现 源码

原文地址:http://blog.csdn.net/laoyang360/article/details/46390293

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!