排课表代码--初步模型

2024-04-19 14:32
文章标签 代码 模型 初步 课表

本文主要是介绍排课表代码--初步模型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

初步模型,并没有实现换教练的。

import copy 
class student():def __init__(self,studentID,isAgent,leftNumsOfCourse,coach2id,coach3id):self.studentID = studentIDself.isAgent = isAgentself.leftNumsOfCourse = leftNumsOfCourseself.coach2id = coach2idself.coach3id = coach3iddef minusLeftNumsOfCourse(self,num):self.leftNumsOfCourse = self.leftNumsOfCourse - numdef addLeftNumsOfCourse(self,num):self.leftNumsOfCourse = self.leftNumsOfCourse + num
#测试建立学生
student1 = student('u201010187',0,23,'c232','c432')
#print(student1.leftNumsOfCourse)
student1.minusLeftNumsOfCourse(3)
#print(student1.leftNumsOfCourse)class coach():def __init__(self,coachid,teamID,coursesid,askForWeek):self.coachid = coachidself.teamID = teamIDself.coursesid = coursesid    #listself.askForWeek = askForWeek   #listdef isAbleToWork(self,day):self.askForWeek.append(day)coach1 = coach('c2232','e33',[2,0,3],[])
#print(coach1.coursesid,coach1.askForWeek)
coach1.isAbleToWork('friday')
#print(coach1.askForWeek)class schedule():def __init__(self,totalSchedule=[],query={}):#   self.coachid = coachidself.totalSchedule = totalScheduleself.query =query   #表索引字典def createBlankSchedule(self,numsOfCourseOneDay=17):  #创建一个新空的一个周期的空表daySchedule = [0 for i in range(numsOfCourseOneDay)]       weekSchedule = [copy.deepcopy(daySchedule) for i in range(7)]return weekScheduledef addCoachSchedule(self,coach,coachSchedule):#添加一个教练表到总教练表中# print(type(coach),coach.coachid)coachSchedule = copy.deepcopy(coachSchedule)numOfCoach = len(self.totalSchedule)self.query['%s'%coach.coachid] = numOfCoach #建立索引self.totalSchedule.append(coachSchedule)def scrapeSchedule(self,son_scheduleIndex=[]):#son_scheduleIndex = ['张三','李四','王五']#则返回的是张三李四王五教练的课表res = []newQuery ={}for coachID in son_scheduleIndex:index = self.query[coachID]numOfCoach = len(newQuery)newQuery[coachID] = numOfCoachres.append(self.totalSchedule[index])return res,newQuerydef isCoachScheduleFull(self,coachname):coachindex = self.query(coachname)coachSchedule = self.totalSchedule[coachindex] #得到这个表for i in range(7):for j in range(17):if coachSchedule[i][j] ==0:return Falsereturn Truedef searchContinuousNumsOfCourse(self,coachname,day):coachindex = self.query(coachname)coachSchedule = self.totalSchedule[coachindex]dayslice = coachSchedule[day]res = []for i in range(17):if dayslice[i]==0:res.append(i)return res  #输出的是[1,2,4,5,6,10,11,12,13,14...]def getScheduleOfCoach(self,coachname): #coachname就是coachidcoachindex = self.query[coachname]coachSchedule = self.totalSchedule[coachindex] #得到这个表return coachScheduledef changeScheduleOfCourse(self,coachname,day,newslice):coachindex = self.query[coachname]print('要改变的coach在教练表中的索引是:',coachindex)# print('教练的某一天的表:',self.totalSchedule[coachindex][day])self.totalSchedule[coachindex][day] = newslice# print(self.totalSchedule)'''每个学员每天的上课数有下限,比如2,每个学员每个上课有上限,比如5'''
def canSatisfyRequirement12(dayslice):count = 0for i in range(17):if i ==0:count =1continueif dayslice[i] ==dayslice[i-1]:count += 1elif count <2:return Falseelif count >5:return Falseelse:count = 1return True'''外地学员的开始和结束课节有限制,我们令限制为Beginninglimit,Endinglimit'''
def canSatisfyRequirement34(dayslice,student,Beginninglimit,Endinglimit):for i in range(Beginninglimit):if dayslice[i] == student.studentID:return Falsefor j in range(Endinglimit,17):if dayslice[j] == student.studentID:return Falsereturn True#schedule1 = schedule()#print(schedule1.createBlankSchedule(17))#def fitcoaches(student,totalschedule):#   coachID = student.coach2id#  '''得到这个教练的教练组,这个教练组的所有教练,是一个list# '''#teamCoach = ['张三','李四','王五']#scrapeSchedule = totalschedule.scrapeSchedule(teamCoach)# return student,scrapeSchedule
'''模拟排课的,输出是模拟排出的课,满足条件才会输出1,第一步判断是不是拆玩后学生的课表满足,要判断是不是超出了学生的接受范围2,检查填进去的slice是不是满足要求,逐个检测,报错就不行的,如果可以的话,就要写进入表了2.x检查临时表是不是时间段冲突,这需要定义一个函数
'''
def choice(student,schedule,coachname,day,studentArrangedSchedule):numsOfCourse = [5,4,3,2]slice1 = schedule.getScheduleOfCoach(coachname)[day]# print('+++no.1+++')# print('进入循环',slice1)preparedslice =[]for num in numsOfCourse:#   print('++++++no.%s+++++++'%num)#  print(slice1)if  num>student.leftNumsOfCourse:           continue  #循环进入下一个student.minusLeftNumsOfCourse(num) #修改进行判断if not isSuitableToStudent(student):student.addLeftNumsOfCourse(num)continuestudent.addLeftNumsOfCourse(num)  #修改回来#2的检测preparedslice = fullslice(slice1,num,student)if not canSatisfyRequirement12(preparedslice):#   print(slice1)print('没有满足条件12......')continueif student.isAgent ==1:            if not canSatisfyRequirement34(preparedslice,student,1,1):print('没有满足条件34.......')continueif isRepeat(studentArrangedSchedule,day,preparedslice):print('没有满足条件,跟已知学生课程时间冲突')continue#如果上面的条件都满足,就把这个数据写到schedule中,也就是原始表中改变slice1#学生的信息也改变,比如课时数'''这里还缺少一个维护学生上课是不是重复的表,考虑到学生是一个个进去选课的,所以这个可以用一个@@@@临时表@@@@维护,当学生选择上某课了,那么这个临时表就得更新'''schedule.changeScheduleOfCourse(coachname,day,preparedslice)student.minusLeftNumsOfCourse(num)print('更新前的表是:',studentArrangedSchedule)updateSchedule(studentArrangedSchedule,day,preparedslice)print('更新后的表是:',studentArrangedSchedule)return Truebreak#  print("this slice is suitable")# print(preparedslice)return False    '''填完课表后,学生的剩余课时数不能为1'''
def isSuitableToStudent(student):if student.leftNumsOfCourse ==1:return Falseelse:return True'''个人的课程是不是重复
schedule1----个人的历史课表
slice1----要检测的某天课程
'''
numsOfCourseOneDay =17
daySchedule = [0 for i in range(numsOfCourseOneDay)]
weekSchedule = [copy.deepcopy(daySchedule) for i in range(7)]
studentSchedule1 = weekSchedule
def isRepeat(studentSchedule1,day,slice1):for i in range(len(slice1)):  #追个检查是不是有重复安排的if (slice1[i] != 0 and studentSchedule1[day][i] !=0):return Truereturn False
def updateSchedule(studentSchedule1,day,slice1):for i in range(len(slice1)):if slice1[i] !=0:studentSchedule1[day][i] = 1
'''
排列出一些位置选择
1,以学员角度,还是以课程为角度。
。。。。以课程的话,选择2,3,5优先选择多的,也就是5的,先检测5,然后检测3,再检测2
。。。。函数f(参数1,参数2,参数3)参数1,slice参数2,填的课,把0填成2或3或5参数3,学生对象
。。。。返回的是排好的slice1,或者返回0,表示本身课不行的
'''
def fullslice(slice1,numOfCourse,student):slice2 = copy.deepcopy(slice1)for i in range(17):if slice2[i]==0:slice2[i]=student.studentIDnumOfCourse = numOfCourse-1if numOfCourse ==0:breakif numOfCourse ==0:return slice2else:return 0schedule1 = schedule()
#print(schedule1.totalSchedule)
newtable = schedule1.createBlankSchedule(17)
coach1 = coach('c102','i234',1,[])
#print(coach1.teamID)
schedule1.addCoachSchedule(coach1,newtable)
#print(schedule1.totalSchedule)
coach2 = coach('c101','i234',1,[])
newtable = schedule1.createBlankSchedule(17)
schedule1.addCoachSchedule(coach2,newtable)
schedule1.changeScheduleOfCourse('c102',2,[2,2,1,1,0,0,1,1,1,0,0,0,5,5,0,0,0])
c = schedule1.totalSchedule
print('原始表:',schedule1.totalSchedule)
#print(schedule1.totalSchedule)
#print(schedule1.query)
#创建几个学生 studentID,isAgent,leftNumsOfCourse,coach2id,coach3id
student1 = student('s001',0,15,'c102','c232')
student2 = student('s002',0,3,'c102','c232')
for i in range(7):print('教练的第%s天'%i)    choice(student1,schedule1,'c102',i,studentSchedule1)print('学生剩余课数:',student1.leftNumsOfCourse)if student1.leftNumsOfCourse <2:break
print('后来表:',schedule1.totalSchedule)

这篇关于排课表代码--初步模型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/917807

相关文章

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工

Java 线程池+分布式实现代码

《Java线程池+分布式实现代码》在Java开发中,池通过预先创建并管理一定数量的资源,避免频繁创建和销毁资源带来的性能开销,从而提高系统效率,:本文主要介绍Java线程池+分布式实现代码,需要... 目录1. 线程池1.1 自定义线程池实现1.1.1 线程池核心1.1.2 代码示例1.2 总结流程2. J

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

Vue实现路由守卫的示例代码

《Vue实现路由守卫的示例代码》Vue路由守卫是控制页面导航的钩子函数,主要用于鉴权、数据预加载等场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、概念二、类型三、实战一、概念路由守卫(Navigation Guards)本质上就是 在路

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

JAVA实现Token自动续期机制的示例代码

《JAVA实现Token自动续期机制的示例代码》本文主要介绍了JAVA实现Token自动续期机制的示例代码,通过动态调整会话生命周期平衡安全性与用户体验,解决固定有效期Token带来的风险与不便,感兴... 目录1. 固定有效期Token的内在局限性2. 自动续期机制:兼顾安全与体验的解决方案3. 总结PS

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

Python屏幕抓取和录制的详细代码示例

《Python屏幕抓取和录制的详细代码示例》随着现代计算机性能的提高和网络速度的加快,越来越多的用户需要对他们的屏幕进行录制,:本文主要介绍Python屏幕抓取和录制的相关资料,需要的朋友可以参考... 目录一、常用 python 屏幕抓取库二、pyautogui 截屏示例三、mss 高性能截图四、Pill

使用MapStruct实现Java对象映射的示例代码

《使用MapStruct实现Java对象映射的示例代码》本文主要介绍了使用MapStruct实现Java对象映射的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、什么是 MapStruct?二、实战演练:三步集成 MapStruct第一步:添加 Mave

Java抽象类Abstract Class示例代码详解

《Java抽象类AbstractClass示例代码详解》Java中的抽象类(AbstractClass)是面向对象编程中的重要概念,它通过abstract关键字声明,用于定义一组相关类的公共行为和属... 目录一、抽象类的定义1. 语法格式2. 核心特征二、抽象类的核心用途1. 定义公共接口2. 提供默认实