鱼C论坛

 找回密码
 立即注册
查看: 2433|回复: 1

选择客寨 c++

[复制链接]
发表于 2018-4-9 20:41:40 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
选择客栈(hotel.cpp/c/pas)NOIP2011 day1
“感觉我们好像穿越了,记得以前看过的电视剧里,好像只要从悬崖上跳下就可以穿越了。”李旭琳不确定地说。
“哈,那种要技术没技术,要思想没思想的神剧,谁信谁傻啊。但不管怎么说,还是先找个客栈住下再说。”张琪曼一副既来之则安之的表情。
已知她们现在所在的世界有一条护城河,河边有n家(2≤n≤200000)很有特色的客栈,客栈按照其位置顺序从1到n编号。每家客栈都按照某一种色调进行装饰(总共k种,用整数0~k-1表示,且0<k≤50),且每家客栈都设有一家咖啡店,每家咖啡店均有各自的最低消费。
张琪曼和李旭琳准备住客栈,她们喜欢相同的色调,又想尝试两个不同的客栈,因此决定分别住在色调相同的两家客栈中。晚上,她们打算选择一家咖啡店喝咖啡,要求咖啡店位于两人住的两家客栈之间(包括她们住的客栈),且咖啡店的最低消费不超过p(0≤p,最低消费≤100)。
她们想知道总共有多少种选择住宿的方案,保证晚上可以找到一家最低消费不超过p元的咖啡店小聚。
【输入格式】
输入文件 hotel.in,共n+1行。
第一行三个整数 n,k,p,每两个整数之间用一个空格隔开,分别表示客栈的个数,色调的数目和能接受的最低消费的最高值;
接下来的 n行,第 i+1 行两个整数,之间用一个空格隔开,分别表示 i 号客栈的装饰色调和 i 号客栈的咖啡店的最低消费。
【输出格式】
     输出文件名为 hotel.out,输出只有一行,一个整数,表示可选的住宿方案的总数。
【输入样例】
5 2 3
0 5  
1 3
0 2
1 4
1 5
【输出样例】
3
【样例说明】
客栈编号: ①  ②  ③  ④  ⑤
色调:      0  1   0   1   1
最低消费:  5  3   2   4   5
2 人要住同样色调的客栈,所有可选的住宿方案包括:住客栈①③,②④,②⑤,④⑤,但是若选择住 4、5 号客栈的话,4、5 号客栈之间的咖啡店的最低消费是 4,而两人能承受的最低消费是 3 元,所以不满足要求。因此只有前 3 种方案可选。
【数据范围】
对于30%的数据,有 n≤100;  
对于50%的数据,有 n≤1000;
对于100%的数据,有 2≤n≤200000,0<k≤50,0≤p≤100, 0≤最低消费≤100。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-4-11 21:20:06 | 显示全部楼层
本帖最后由 qq1242009750 于 2018-4-11 21:32 编辑
  1. #include "stdafx.h"
  2. #include <iostream>
  3. #include <fstream>
  4. using namespace std;

  5. #define IN_FILENAME "hotel.in"
  6. #define OUT_FILENAME "hotel.out"

  7. struct Hotel
  8. {
  9.         int style;
  10.         int expenditure;
  11. };

  12. class CInn
  13. {
  14. public:
  15.         CInn()
  16.         {
  17.                 ifstream ifs;
  18.                 ifs.open(IN_FILENAME);
  19.                 if (!ifs)
  20.                 {
  21.                         cout << "文件打开失败!" << endl;
  22.                 }
  23.                 ifs >> m_num >> m_style >> m_expenditure;
  24.                 m_Array = new Hotel[m_num];

  25.                 for (int i = 0; ; ++i)
  26.                 {
  27.                         ifs >> m_Array[i].style;
  28.                         ifs >> m_Array[i].expenditure;
  29.                         if (ifs.eof())
  30.                                 break;
  31.                 }

  32.                 ifs.close();
  33.         }

  34.         void CalcNum()        //计算符合条件的总和并打印文件
  35.         {
  36.                 ofstream ofs;
  37.                 ofs.open(OUT_FILENAME);
  38.                 int Sum = 0;
  39.                 for (int i = 0; i < m_style; ++i)
  40.                 {
  41.                         Sum += Sort(i);
  42.                 }
  43.                 ofs << Sum << endl;
  44.         }

  45.         ~CInn()
  46.         {
  47.                 if (m_Array)
  48.                         delete[] m_Array;
  49.         }
  50. private:
  51.         int m_num, m_style, m_expenditure;
  52.         Hotel *m_Array;

  53.         int Sort(int StyleNum)
  54.         {
  55.                 int Sum = 0;
  56.                 for (int i = 0; i < m_num; ++i)                //计算某个风格客栈的总和
  57.                 {
  58.                         if (m_Array[i].style == StyleNum )
  59.                                 ++Sum;
  60.                 }
  61.                 Hotel *StyleArray = new Hotel[Sum];
  62.                 for (int i = 0, j = 0; i < m_num; ++i)        //保存符合风格的客栈
  63.                 {
  64.                         if (m_Array[i].style == StyleNum)
  65.                         {
  66.                                 StyleArray[j] = m_Array[i];
  67.                                 ++j;
  68.                         }
  69.                 }

  70.                 int HSum = 0;
  71.                 for (int i = 0; i < Sum - 1; ++i)        //计算可能性
  72.                 {
  73.                         for (int j = i + 1; j < Sum; ++j)
  74.                         {
  75.                                 if (StyleArray[i].expenditure <= m_expenditure || StyleArray[j].expenditure <= m_expenditure)        //计算符合花费的客栈
  76.                                         ++HSum;
  77.                         }
  78.                 }
  79.                 delete []StyleArray;
  80.                 return HSum;
  81.         }
  82. };

  83. int main(void)
  84. {
  85.         CInn a;
  86.         a.CalcNum();
  87.        
  88.         system("pause");
  89.     return 0;
  90. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-3-29 14:06

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表