团体程序设计天梯赛-练习集 L1-043 阅览室 代码没有通过,不知道哪里没有考虑到
团体程序设计天梯赛-练习集 L1-043 阅览室
题目:
天梯图书阅览室请你编写一个简单的图书借阅统计程序。当读者借书时,管理员输入书号并按下**S**键,程序开始计时;当读者还书时,管理员输入书号并按下**E**键,程序结束计时。书号为**不超过1000的正整数**。当管理员将**0**作为书号输入时,表示一天工作结束,你的程序应**输出当天的读者借书次数和平均阅读时间**。
注意:由于线路偶尔会有故障,可能出现不完整的纪录,即只有S没有E,或者只有E没有S的纪录,系统应能自动忽略这种无效纪录。另外,题目保证书号是书的唯一标识,同一本书在任何时间区间内只可能被一位读者借阅。**
输入格式
输入在第一行给出一个**正整数N(≤10)**,随后给出**N天**的纪录。每天的纪录由若干次借阅操作组成,**每次操作占一行**,格式为:
书号([1, 1000]内的整数) 键值(S或E) 发生时间(hh:mm,其中hh是[0,23]内的整数,mm是[0, 59]内整数)每一天的纪录保证按时间递增的顺序给出。
输出格式:
对每天的纪录,在一行中输出当天的读者借书次数和平均阅读时间(以分钟为单位的精确到个位的整数时间)。
输入样例:
3
1 S 08:10
2 S 08:35
1 E 10:00
2 E 13:16
0 S 17:00
0 S 17:00
3 E 08:10
1 S 08:20
2 S 09:00
1 E 09:20
0 E 17:00
输出样例:
2 196
0 0
1 60
实现代码:(.cpp)
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 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 | #include<iostream> #include<cmath> using namespace std; int main() { int n; cin>>n; int time[1001]={0}; int count=0; double alltime=0; char c,g; int m; int hh,mm; while (n>0) { // 书的序号(m) (c)书的状态 cin>>m>>c>>hh>>g>>mm; if (m==0) { //一天结束 //cout<<"第"<<i<<"天"; cout<<count<< " " ; if (count>0) { cout<<round(alltime/count)<<endl; } else { cout<<count<<endl; } //每天初始化 for ( int i=0; i<1001; i++) { time[i]=0; } n--; count=0; c=g= ' ' ; } else { if ( c== 'S' && time[m]==0 ) { //没借出的书才能借 time[m]=hh*60+mm; //cout<<c<<" "<<hh<<" "<<mm<<endl; } else if (c== 'E' && time[m]!=0) { //已借出的书才能还 alltime+=hh*60+mm-time[m]; time[m]=0; //书名为m的书归还成功 //cout<<m<<" "<<hh*60+mm<<" "<<time[m]<<endl; count++; } } } return 0; } |
##代码没有通过,不知道哪里没有考虑到
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述