这是2017年蓝桥杯C组C++的压轴题,拿到之后没什么想法。但是蓝桥杯有部分分。所以直接敲了个大暴力提交上去过了一半的数据。后来想到了DP,但是没能实现出来,感觉还是有问题的。后来看了解题视频发现是预处理。

  • 大暴力

    图形排版 739B C++ 运行超时 50 运行超时 1.585MB
    #include "cstdio"
    #include "algorithm"
    using namespace std;
    typedef pair<int, int> PII;
    const int MAXN = ;
    const int INF = 0x3f3f3f3f;
    PII arr[MAXN];
    int n, m;
    int check(int id) {
    int k = n, cnt = , h = ;
    for (int i = ; i < m; i++) {
    if (i == id) {
    continue;
    }
    if (k > arr[i].first) {
    k -= arr[i].first;
    h = max(h, arr[i].second);
    } else {
    h = max(h, (arr[i].second * k - ) / arr[i].first + );
    k = n;
    cnt += h;
    h = ;
    }
    }
    if (h != ) {
    cnt += h;
    }
    return cnt;
    }
    int main() {
    scanf("%d%d", &n, &m);
    for (int i = ; i < m; i++) {
    scanf("%d%d", &arr[i].first, &arr[i].second);
    }
    int mn = INF;
    for (int i = ; i < m; i++) {
    mn = min(mn, check(i));
    }
    printf("%d\n", mn);
    return ;
    }

    比赛想不到后面的方法感觉这个方法也够了,毕竟我做到最后一题的时候时间已经不多了。

  • 预处理
    图形排版 1.300KB C++ 正确 100 62ms 2.070MB
    #include "cstdio"
    #include "iostream"
    #include "algorithm"
    using namespace std;
    typedef pair<int, int> PII;
    const int MAXN = ;
    const int INF = 0x3f3f3f3f;
    // 存n张图片,first为宽,second为高
    PII arr[MAXN];
    // 预处理,f[i]表示第i张图到第n张图需要的高度
    int f[MAXN];
    int n, m;
    // Add用于往一个行里加入第k张图片
    void Add(PII* p, int k) {
    if (p->first + arr[k].first < m) {
    p->first += arr[k].first;
    p->second = max(p->second, arr[k].second);
    } else {
    p->second = max(p->second, (arr[k].second * (m - p->first) - ) / arr[k].first + );
    p->first = m;
    }
    }
    int getF(PII p, int k) {
    while (k <= n && p.first < m) {
    Add(&p, k);
    k++;
    }
    // 因为已经求出f[k]了,所以k后面就不用再算了;
    return p.second + f[k];
    }
    int main() {
    scanf("%d%d", &m, &n);
    for (int i = ; i <= n; i++) {
    scanf("%d%d", &arr[i].first, &arr[i].second);
    }
    for (int i = n; i >= ; i--) {
    f[i] = getF(make_pair(, ), i);
    }
    // pre表示在now表示的行上面已经存在的高度;
    int pre = , res = INF;
    // now表示当前正在填充的行
    PII now = make_pair(, );
    for (int i = ; i <= n; i++) {
    res = min(res, pre + getF(now, i + ));
    Add(&now, i);
    if (now.first == m) {
    pre += now.second;
    now.first = now.second = ;
    }
    }
    printf("%d\n", res);
    return ;
    }

蓝桥杯-PREV45-图形排版的更多相关文章

  1. Java实现蓝桥杯打印图形

    标题:打印图形 如下的程序会在控制台绘制分形图(就是整体与局部自相似的图形). 当n=1,2,3的时候,输出如下: 请仔细分析程序,并填写划线部分缺少的代码. n=1时: o ooo o n=2时: ...

  2. Java实现第八届蓝桥杯图形排版

    标题:图形排版 小明需要在一篇文档中加入 N 张图片,其中第 i 张图片的宽度是 Wi,高度是 Hi. 假设纸张的宽度是 M,小明使用的文档编辑工具会用以下方式对图片进行自动排版: 1. 该工具会按照 ...

  3. 2012年 蓝桥杯预赛 java 本科 题目

    2012年 蓝桥杯预赛 java 本科 考生须知: l  考试时间为4小时. l  参赛选手切勿修改机器自动生成的[考生文件夹]的名称或删除任何自动生成的文件或目录,否则会干扰考试系统正确采集您的解答 ...

  4. 第八届蓝桥杯JavaB---承压计算

    标题:承压计算 X星球的高科技实验室中整齐地堆放着某批珍贵金属原料. 每块金属原料的外形.尺寸完全一致,但重量不同. 金属材料被严格地堆放成金字塔形. 7 5 8 7 8 8 9 2 7 2 8 1 ...

  5. 2018年蓝桥杯B组C/C++决赛题目

    自己的博客排版,自我感觉略好一点. 先放上题目. 点击查看2018年蓝桥杯B组C/C++决赛题目题解     1.换零钞 x星球的钞票的面额只有:100元,5元,2元,1元,共4种. 小明去x星旅游, ...

  6. [算法竞赛][2018][蓝桥杯][LanqiaoCA]第九届蓝桥杯A组

    题目1 标题:分数 1/1 + 1/2 + 1/4 + 1/8 + 1/16 + .... 每项是前一项的一半,如果一共有20项,求这个和是多少,结果用分数表示出来.类似:3/2当然,这只是加了前2项 ...

  7. 第四届蓝桥杯JavaC组省赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.猜年龄 题目描述 美国数学家维纳(N.Wiener)智力早熟,11岁就上了大学.他曾在1935~1936年应邀来中国清华大学讲学. 一 ...

  8. 第九届蓝桥杯JavaC组省赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.哪天返回 题目描述 小明被不明势力劫持.后被扔到x星站再无问津.小明得知每天都有飞船飞往地球,但需要108元的船票,而他却身无分文. ...

  9. 第九届蓝桥杯JavaA组省赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.分数 题目描述 1/1 + 1/2 + 1/4 + 1/8 + 1/16 + - 每项是前一项的一半,如果一共有20项, 求这个和是多 ...

随机推荐

  1. PROOF|ADOBE READER

    样稿PROOF,最后是印刷样张. 修改校样是最后一次修改错误. 每一版editor不一样,任务不同. 不能修改工作单位,但是可以加一个标注. 最好使用ADOBE READER中的COMMENT& ...

  2. POJ-1703 Find them, Catch them(并查集&数组记录状态)

    题目: The police office in Tadu City decides to say ends to the chaos, as launch actions to root up th ...

  3. UML-如何创建领域模型?

    以当前迭代中所要设计的需求为界: 1.寻找概念类 2.将其绘制为类图 3.添加关联和属性

  4. 2.Jenkins结合k8s完成Jenkins slave功能

    1.构建镜像 下载基础镜像,这里使用openvz的包,下载地址为:https://wiki.openvz.org/Download/template/precreated,下载centos7的镜像 下 ...

  5. 洛谷 P3371 【模板】单源最短路径(弱化版)(dijkstra邻接链表)

    题目传送门 解题思路: 传送门 AC代码: #include<iostream> #include<cstdio> #include<cstring> using ...

  6. Linux进程的引入

    1.什么是进程? (1).进程是一个动态过程而不是静态实物 (2).进程就是程序的一次运行过程,一个静态的可执行程序a.out的一次运行过程(./a.out从运行到结束)就是一个进程. (3).进程控 ...

  7. MySql数据库,查询数据导出时会出现重复的记录(数据越多越明显)

    在查询数据时,数据量多的时候,我们会使用分页功能. 每页显示多少数据. 这种情况下,一半看不出什么问题. 而导出数据时,有时就是通过分页的方法,逐步讲数据追加到导出文件中. 当全部数据都导出之后,就有 ...

  8. 关于sql更新最后一个逗号的去除或则最后的and的去除

    去除最后的逗号substr_replace($update_sql ,"",-1);去除最后的and substr_replace($update_sql ,"" ...

  9. Python笔记_第三篇_面向对象_9.Python中的"get"和"set"方法(@property和@.setter)

    1. 限制访问的问题: 如果学过C# 语言的我们可以知道C# 语言有get和set方法.我们之前想要获取父类中的私有变量,只能通过写一个set和get的函数进行访问或者通过类生成的新关键字来访问私有属 ...

  10. DispatcherServlet和ContextLoaderListener,还有spring+servlet3.0 无web.xml启动问题

    上篇提到: 关于spring +springmvc中两个spring应用上下文(DispatcherServlet和ContextLoaderListener)的问题,挺让人迷糊的. 他们都是加载Be ...