题目链接:https://cn.vjudge.net/contest/283924#problem/B

题目大意:给你n个人的信息,让你找出一个时间,要求让你选择一天,使得这一天的前一个生日距离它最远,如果有多个一样的,有点选择10月27之后的。

AC代码:

  1. #include<iostream>
  2. #include<stack>
  3. #include<cstring>
  4. #include<iomanip>
  5. #include<stdio.h>
  6. #include<algorithm>
  7. #include<cmath>
  8. using namespace std;
  9. # define ll long long
  10. # define inf 0x3f3f3f3f
  11. # define lson l,m,rt<<
  12. # define rson m+,r,rt<<|
  13. const int maxn = 2e5+;
  14. struct node
  15. {
  16. int m;
  17. int d;
  18. int day;
  19. bool friend operator < (node t1,node t2)
  20. {
  21. return t1.day<t2.day;
  22. }
  23. } q[maxn];
  24. char u;
  25. char str[maxn];
  26. int sto[maxn];
  27. int a[maxn];
  28. int f[]= {,,,,,,,,,,,};
  29. int cal(int t1,int t2)
  30. {
  31. int ans=;
  32. for(int i=; i<t1-; i++)
  33. {
  34. ans+=f[i];
  35. }
  36. ans+=t2;
  37. return ans;
  38. }
  39. int main()
  40. {
  41. // freopen("data1.in","r",stdin);
  42. int n,m,d;
  43. scanf("%d",&n);
  44. if(n==)
  45. {
  46. cin>>str;
  47. cin>>q[].m>>u>>q[].d;
  48. int i,tot=cal(q[].m,q[].d)-;
  49. for( i=; i<; i++)
  50. {
  51. if(tot-f[i]>=)
  52. tot-=f[i];
  53. else
  54. break;
  55. }
  56. if(tot==)
  57. {
  58. i--;
  59. if(i==-)
  60. i=;
  61. tot=f[i];
  62. }
  63. printf("%02d-%02d\n",i+,tot);
  64. return ;
  65. }
  66. for(int i=; i<=n; i++)
  67. {
  68. cin>>str;
  69. cin>>q[i].m>>u>>q[i].d;
  70. q[i].day=cal(q[i].m,q[i].d);
  71. }
  72. sort(q+,q+n+);
  73. sto[]=-q[n].day+q[].day;
  74. for(int i=; i<=n; i++)
  75. {
  76. sto[i]=q[i].day-q[i-].day;
  77. }
  78. int maxx=;
  79. for(int i=; i<=n; i++)
  80. {
  81. maxx=max(maxx,sto[i]);
  82. }
  83. int num=,id;
  84. for(int i=; i<=n; i++)
  85. {
  86. if(maxx==sto[i])
  87. {
  88. a[++num]=i;
  89. }
  90. }
  91. // cout<<num<<endl;
  92. if(num==)
  93. {
  94. int i,tot=sto[a[]]+q[a[]-].day-;
  95. if(a[]==)tot=q[].day-;
  96. tot=(tot+)%;
  97. for(i=; i<; i++)
  98. {
  99. if(tot-f[i]>=)
  100. tot-=f[i];
  101. else
  102. break;
  103. }
  104. if(tot==)
  105. {
  106. i--;
  107. if(i==-)
  108. i=;
  109. tot=f[i];
  110. }
  111. printf("%02d-%02d\n",i+,tot);
  112. }
  113. else
  114. {
  115. int flag=;
  116. int minn1=inf;
  117. int minn2=inf;
  118. int pos;
  119. for(int i=; i<=num; i++)
  120. {
  121. int tmp=sto[a[i]]+q[a[i]-].day-;
  122. if(tmp>)
  123. tmp-=;
  124. if(tmp>cal(,))
  125. {
  126. if(tmp-cal(,)<minn1)
  127. {
  128. minn1=tmp-cal(,);
  129. flag=i;
  130. }
  131. }
  132. else
  133. {
  134. if((tmp-cal(,))<minn2)
  135. {
  136. minn2=tmp-cal(,);
  137. pos=i;
  138. }
  139. }
  140. }
  141. // cout<<minn1<<endl;
  142. int i,tot;
  143. if(minn1!=inf)
  144. {
  145. i,tot=sto[a[flag]]+q[a[flag]-].day-;
  146. tot=(tot+)%;
  147. for( i=; i<; i++)
  148. {
  149. if(tot-f[i]>=)
  150. tot-=f[i];
  151. else
  152. break;
  153. }
  154. }
  155. else
  156. {
  157. tot=q[pos].day-;
  158. tot=(tot+)%;
  159. for( i=; i<; i++)
  160. {
  161. if(tot-f[i]>=)
  162. tot-=f[i];
  163. else
  164. break;
  165. }
  166. }
  167. if(tot==)
  168. {
  169. i--;
  170. if(i==-)
  171. i=;
  172. tot=f[i];
  173. }
  174. printf("%02d-%02d\n",i+,tot);
  175. }
  176. return ;
  177. }

B - Birthday Boy Gym - 102007B的更多相关文章

  1. ACM: Gym 101047M Removing coins in Kem Kadrãn - 暴力

     Gym 101047M Removing coins in Kem Kadrãn Time Limit:2000MS     Memory Limit:65536KB     64bit IO Fo ...

  2. ACM: Gym 101047K Training with Phuket's larvae - 思维题

     Gym 101047K Training with Phuket's larvae Time Limit:2000MS     Memory Limit:65536KB     64bit IO F ...

  3. ACM: Gym 101047E Escape from Ayutthaya - BFS

    Gym 101047E Escape from Ayutthaya Time Limit:2000MS     Memory Limit:65536KB     64bit IO Format:%I6 ...

  4. ACM: Gym 101047B Renzo and the palindromic decoration - 手速题

     Gym 101047B  Renzo and the palindromic decoration Time Limit:2000MS     Memory Limit:65536KB     64 ...

  5. Gym 101102J---Divisible Numbers(反推技巧题)

    题目链接 http://codeforces.com/gym/101102/problem/J Description standard input/output You are given an a ...

  6. Gym 100917J---Judgement(01背包+bitset)

    题目链接 http://codeforces.com/gym/100917/problem/J Description standard input/outputStatements The jury ...

  7. Gym 100917J---dir -C(RMQ--ST)

    题目链接 http://codeforces.com/gym/100917/problem/D problem description Famous Berland coder and IT mana ...

  8. Gym 101102D---Rectangles(单调栈)

    题目链接 http://codeforces.com/gym/101102/problem/D problem  description Given an R×C grid with each cel ...

  9. Gym 101102C---Bored Judge(区间最大值)

    题目链接 http://codeforces.com/gym/101102/problem/C problem description Judge Bahosain was bored at ACM ...

随机推荐

  1. BZOJ4386[POI2015]Wycieczki——矩阵乘法+倍增

    题目描述 给定一张n个点m条边的带权有向图,每条边的边权只可能是1,2,3中的一种.将所有可能的路径按路径长度排序,请输出第k小的路径的长度,注意路径不一定是简单路径,即可以重复走同一个点. 输入 第 ...

  2. 七牛云注册创建oss并配置自定义域名

    1.登陆官网注册账号 有个人和企业两种,根据自己的情况进行注册 https://portal.qiniu.com/signup/choice 2.注册后要进行认证,不认证是没有免费空间给你使用的 3. ...

  3. hdu 4897 Little Devil I (树链剖分+线段树)

    题目链接:  http://acm.hdu.edu.cn/showproblem.php?pid=4897 题意: 给你一棵树,一开始每条边都是白色,有三种操作: 1.将 u - v路径上的边转换颜色 ...

  4. 自学Linux Shell4.2-监测磁盘空间mount umount df du

    点击返回 自学Linux命令行与Shell脚本之路 4.2-监测磁盘空间mount umount  df du 1. 挂载存储媒体mount  移除存储媒体umount ls命令用于显示文件目录列表, ...

  5. 自学Zabbix3.12.5-动作Action-Condition配置

    点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 3.12.5 自学Zabbix3.12.5-动作Action-Condition配置 报警,肯定是 ...

  6. SharePoint 2013 APP 开发示例 (六)服务端跨域访问 Web Service (REST API)

    上个示例(SharePoint 2013 APP 开发示例 (五)跨域访问 Web Service (REST API))是基于JavaScript,运行在web browser内去访问REST AP ...

  7. 【POJ1187】陨石的秘密

    题目大意: 定义一个串:只含有 '( )','[ ]','{ }',3种(6个)字符. 定义 SS 串: 空串是SS表达式. 若A是SS表达式,且A串中不含有中括号和大括号,则(A)是SS表达式. 若 ...

  8. vcf文件(call variants得来的)怎么看变异是纯合还是杂合的

    如下图片所示: 对于位置为48245131的allele来说,REF为A,ALT为C 想确定变异到底是纯合还是杂合,即两条染色体是否同时发生了变异,则看GT,GT对应的数值为0/1,说明该变异为杂合: ...

  9. MyEclipse新建工作空间后的配置详细步骤

    1. General --> Workspace --> UTF-8 2. General --> Editors -->File  Associations --> J ...

  10. Failed to load because no supported source was found

    Uncaught (in promise) DOMException: Failed to load because no supported source was found? 等待解决: