php+vue企业会议室申请预约考勤管理系统
Posted QQ242219979
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了php+vue企业会议室申请预约考勤管理系统相关的知识,希望对你有一定的参考价值。
运行环境:phpstudy/wamp/xammp等
开发语言:php
后端框架:Thinkphp5
前端框架:vue.js
服务器:apache
数据库:mysql
数据库工具:Navicat/phpmyadmin
开发软件:hbuilderx/vscode/Dreamweaver/PhpStorm等
前端技术:nodejs+vue+elementui。通过对当今互联网的发展的方式现状进行调查、统计和分析,明确网上会议室预约系统对于现代企业办公资源管理的方式影响,同时考虑到了未来几年的发展需求,设计了一个界面美观,公共能完善,满足用户需求的会议室预约系统。本控制系统主要是通过对会议室的使用时间进行网上采集排列,以可视化的数字和图片展现在我们的面前,使我们对会议室资源有更直观的了解,并可以直接从网上预约,节省了繁琐的线下预约流程。
选题系统中的特色及创新点
1会议室信息维护
(1)会议室的基本信息包括会议室的各种各种属性,如:会议室所在位置、可容纳人数、是否具有多媒体设备、能否联网等。申请者可以直接的定位自己所在的会议室;管理员可以对会议室基本信息进行维护,包括增、删、改、查四种功能。管理员可以通过系统的会议模块新增一条会议室信息,并设定会议室的各项属性值;可以删除已有会议室的信息;修改功能实现会议室信息的改动与保存;查询功能实现对现有会议室信息进行查看。系统提供界面友好的vue界面,该界面应清晰明了的展示这些功能。
(2)会议室占用情况是通过日历组件展示的,通过这一功能。会议室申请者可以清晰明了的了解当前会议室的占用情况、占用时间、申请人、联系方式。已批准的申请与未批准的申请分别以不同颜色标注,方便申请者区分。双击日历上的某一天即可进入会议室申请界面。
2会议室的申请
会议室申请功能包括申请会议室及申请信息查看两部分。
(1) 申请会议室:会议室申请操作在日历组件中通过Java脚本语言实现。双击要申请的日期,触发双击事件,调用添加申请功能,进入申请页面。申请人填写申请页面的各项属性,包括开始时间、结束时间、会议内容、联系方式、会议人数等,申请人,申请人单位等信息由系统自动获取,不需要人工填写。申请信息填写完成后就可以提交申请, 提交后系统可以对已过期的日期,不合法的申请时间给出友好的提示(该申请日期已过期或该日期已有人申请), 申请人应该根据提示修改自己的申请信息。会议室申请成功提交后,申请单就进入申请流程。会议室申请通过平台流程设计器实现申请的流转, 逐级审批通过后该申请方可生效。申请人首先将申请表提交给部门领导申请, 若部门领导审批不通过,申请会被打回给申请人,若部门领导审批通过,申请将发送到会议室管理员处,管理员审批不通过申请会被打回给申请人,审批通过后日历上的申请信息将变为红色。可通过筛选会议室条件进行查找、筛选,方便预定合适的会议室。
(2) 查看申请信息:普通用户只能查看本人提交的会议室申请,对拟稿中的申请条目可以进行删、改处理,可以查看当前申请的流转过程,每一步流程的处理意见及被退回申请的原因。会议室管理员可以对全部申请进行增、删、改、查操作。
3 特色或创新之处
系统界面简洁、大方,设计人性化。操作简单。企业中的员工能够很快的熟练使用,不需要进行培训。提高了会议室的利用效率,减少各部门因为会议室的使用而引发冲突,能对会议室资源进行合理合理配置。
[SHOI2009]会场预约
(ORZ)据说这个题有四种写法…我孔乙己表示只会一种。(暂时的)
(color{red}{Description})
PP大厦有一间空的礼堂,可以为企业或者单位提供会议场地。这些会议中的大多数都需要连续几天的时间(个别的可能只需要一天),不过场地只有一个,所以不同的会议的时间申请不能够冲突。也就是说,前一个会议的结束日期必须在后一个会议的开始日期之前。所以,如果要接受一个新的场地预约申请,就必须拒绝掉与这个申请相冲突的预约。 一般来说,如果PP大厦方面事先已经接受了一个会场预约,例如从10日到15日,就不会在接受与之相冲突的预约,例如从12日到17日。不过,有时出于经济利益,PP大厦方面有时会为了接受一个新的会场预约,而拒绝掉一个甚至几个之前预订的预约。 于是,礼堂管理员QQ的笔记本上笔记本上经常记录着这样的信息: 本题中为方便起见,所有的日期都用一个整数表示。例如,如果一个为期10天的会议从“90日”开始到“99日”,那么下一个会议最早只能在“100日”开始。 最近,这个业务的工作量与日俱增,礼堂的管理员QQ希望参加SHTSC的你替他设计一套计算机系统,方便他的工作。这个系统应当能执行下面两个操作: A操作:有一个新的预约是从“start日”到“end日”,并且拒绝掉所有与它相冲突的预约。执行这个操作的时候,你的系统应当返回为了这个新预约而拒绝掉的预约个数,以方便QQ与自己的记录相校对。 B操作:请你的系统返回当前的仍然有效的预约的总数。
(color{red}{Solution \_1})
我们考虑建一棵平衡树,那么上边的每个点代表的是一个预约类,类里面是两个(public),(l)和(r)。
那么事实上,我们可以每一次插入时(logn)二分查找一下所在位置,然后向前向后不断删除有交集的(nodes)。
(however),对于二分查找而言,我们需要一个优先级,那么不妨按照右端点排序。(好像按照左端点排序也可以)
在这个地方记录一个巧妙的方法:(set)的二分删除
就是这段代码:
while(1){
set<hotel>::iterator it=qwq.lower_bound(temp);
if(it->st<=b&&it->ed>=a){
qwq.erase(*it);
cnt++;
continue;
}
it=qwq.lower_bound(temp);
if(it!=qwq.begin()){
it--;
if(it->st<=b&&it->ed>=a){
qwq.erase(*it);
cnt++;
continue;
}
}
break;
}
第一个(if)向后删除,第二个(if)向前删除。
而这一段代码的执行顺序很显然:
删完二分所得位置之后的,删不完就continue继续删,删完二分所得位置之前的,删不完就continue继续删,最后break。
反正我是被这个操作秀了一脸(OTZ).
嗯,这个操作就叫做二分删除啦!!(雾
#include<algorithm>
#include<cstdio>
#include<iostream>
#include<set>
using namespace std;
struct hotel{
int st,ed;
hotel(){}
hotel (int l,int r){
st=l;
ed=r;
}
bool operator < (const hotel &cmp)const{
return ed<cmp.ed;
}
};
char c;
int m,cnt,a,b;
set<hotel>qwq;
int main(){
cin>>m;
for(register int i=1;i<=m;i++){
cin>>c;
if(c==‘A‘){
scanf("%d%d",&a,&b);
hotel temp=hotel(a,b);
cnt=0;
while(1){
set<hotel>::iterator it=qwq.lower_bound(temp);
if(it->st<=b&&it->ed>=a){
qwq.erase(*it);
cnt++;
continue;
}
it=qwq.lower_bound(temp);
if(it!=qwq.begin()){
it--;
if(it->st<=b&&it->ed>=a){
qwq.erase(*it);
cnt++;
continue;
}
}
break;
}
qwq.insert(temp);
cout<<cnt<<endl;
}
else cout<<qwq.size()<<endl;
}
}
(Ps:) 用(cin)比(scanf+register)慢了1400ms……阔怕
(color{red}{Solution \_2})
用线段树做……暂时还不会(QAQ)。
又留了一个坑(ORZ)
以上是关于php+vue企业会议室申请预约考勤管理系统的主要内容,如果未能解决你的问题,请参考以下文章
基于springboot前端Vue的在线办公网站的设计与实现.rar(论文+项目源码)
Java项目:在线淘房系统(租房购房)(java+SpringBoot+Redis+MySQL+Vue+SpringSecurity+JWT+ElasticSearch+WebSocket)