2304512295 发表于 2018-4-9 20:41:40

选择客寨 c++

选择客栈(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
【样例说明】
客栈编号: ①②③④⑤
色调:      01   0   1   1
最低消费:53   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。

qq1242009750 发表于 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;

                for (int i = 0; ; ++i)
                {
                        ifs >> m_Array.style;
                        ifs >> m_Array.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.style == StyleNum )
                                ++Sum;
                }
                Hotel *StyleArray = new Hotel;
                for (int i = 0, j = 0; i < m_num; ++i)        //保存符合风格的客栈
                {
                        if (m_Array.style == StyleNum)
                        {
                                StyleArray = m_Array;
                                ++j;
                        }
                }

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

int main(void)
{
        CInn a;
        a.CalcNum();
       
        system("pause");
    return 0;
}
页: [1]
查看完整版本: 选择客寨 c++