记录编号 133407 评测结果 AAAAAAAAAA
题目名称 [NOIP 2011]选择客栈 最终得分 100
用户昵称 Gravatar 是否通过 通过
代码语言 C++ 运行时间 0.142 s
提交时间 2014-10-27 21:26:33 内存使用 2.79 MiB
显示代码纯文本
  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstdlib>
  4. using namespace std;
  5. struct point
  6. {
  7. int pri;
  8. int co;
  9. }a[200001];
  10. int n,k,p;
  11. bool coflag[51]={0};
  12. bool priflag[200001]={0};
  13. int aa[200001];
  14. int main()
  15. {
  16. freopen("hotel.in","r",stdin);
  17. freopen("hotel.out","w",stdout);
  18. scanf("%d%d%d",&n,&k,&p);
  19. for(int i=1;i<=n;i++)
  20. {
  21. scanf("%d%d",&a[i].co,&a[i].pri);
  22. if(!coflag[a[i].co])coflag[a[i].co]=1;
  23. if(a[i].pri<=p)priflag[i]=1;
  24. }
  25. long long ans=0,tmp=0;
  26. for(int i=0;i<k;i++)
  27. {
  28. int len=0;
  29. if(coflag[i]==1)
  30. {
  31. for(int j=1;j<=n;j++)
  32. {
  33. if(a[j].co==i)
  34. {
  35. len++;
  36. aa[len]=j;
  37. }
  38. }
  39. if(len>1)
  40. for(int j=1;j<=len;j++)
  41. {
  42. for(int kk=j+1;kk<=len;kk++)
  43. {
  44. int nimei=0;
  45. for(int m=aa[j];m<=aa[kk];m++)
  46. {
  47. if(priflag[m]==1)
  48. {
  49. nimei=1;
  50. ans+=(len-kk+1);
  51. break;
  52. }
  53. }
  54. if(nimei==1)break;
  55. }
  56. }
  57.  
  58. }
  59. }
  60. printf("%lld",ans);
  61. // system("pause");
  62.  
  63. }