鱼C论坛

 找回密码
 立即注册
查看: 2737|回复: 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 编辑
#include "stdafx.h"
#include <iostream>
#include <fstream>
using namespace std;

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

struct Hotel
{
        int style;
        int expenditure;
};

class CInn
{
public:
        CInn()
        {
                ifstream ifs;
                ifs.open(IN_FILENAME);
                if (!ifs)
                {
                        cout << "文件打开失败!" << endl;
                }
                ifs >> m_num >> m_style >> m_expenditure;
                m_Array = new Hotel[m_num];

                for (int i = 0; ; ++i)
                {
                        ifs >> m_Array[i].style;
                        ifs >> m_Array[i].expenditure;
                        if (ifs.eof())
                                break;
                }

                ifs.close();
        }

        void CalcNum()        //计算符合条件的总和并打印文件
        {
                ofstream ofs;
                ofs.open(OUT_FILENAME);
                int Sum = 0;
                 for (int i = 0; i < m_style; ++i)
                {
                        Sum += Sort(i);
                }
                ofs << Sum << endl;
        }

        ~CInn()
        {
                if (m_Array)
                        delete[] m_Array;
        }
private:
        int m_num, m_style, m_expenditure;
        Hotel *m_Array;

        int Sort(int StyleNum)
        {
                int Sum = 0;
                 for (int i = 0; i < m_num; ++i)                //计算某个风格客栈的总和
                {
                        if (m_Array[i].style == StyleNum )
                                ++Sum;
                }
                Hotel *StyleArray = new Hotel[Sum];
                for (int i = 0, j = 0; i < m_num; ++i)        //保存符合风格的客栈
                {
                        if (m_Array[i].style == StyleNum)
                        {
                                StyleArray[j] = m_Array[i];
                                ++j;
                        }
                }

                int HSum = 0;
                for (int i = 0; i < Sum - 1; ++i)        //计算可能性
                {
                        for (int j = i + 1; j < Sum; ++j)
                        {
                                if (StyleArray[i].expenditure <= m_expenditure || StyleArray[j].expenditure <= m_expenditure)        //计算符合花费的客栈
                                        ++HSum;
                        }
                }
                delete []StyleArray;
                return HSum;
        }
};

int main(void)
{
        CInn a;
        a.CalcNum();
        
        system("pause");
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-10-1 19:20

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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