2015年第六届蓝桥杯B组C/C++决赛题解

点击查看2015年第六届蓝桥杯B组C/C++国赛题目(不含答案)
 
 

1.积分之迷

三重循环 枚举A,B,C的值,如果满足两个条件:3个A + 7个B + 1个C = 15 ,4个A + 10个B + 1个C = 420 就是一组合法的解。 输出A+B+C就是答案
 
 

2.完美正方形

一开始以为很难,看了题解 都是用dfs暴力搜出来的
国赛第二题永远是用dfs解决。。
下面博客dfs的很完美啊!
参考博客:https://blog.csdn.net/liangzhaoyang1/article/details/51571031

思路:dfs(x,y) 正方形想象成边长是47+46+61的网格(每个网格边长为1),
还剩下19个小正方形;
从 (0,0) 网格点开始搜,作为小正方形的(左上角的顶点),枚举19个小正方形放在当前网格里
搜索过程中标记是否使用过这块网格、是否使用过这个小正方形
 
 

3.关联账户

并查集思想
 
 

4.密文搜索

30%数据点:

按题目要求 全排列子串,用STL内置函数在主串中查找,string.find(s) != string::npos;

30-50%数据:

参考博客:https://blog.csdn.net/u014552756/article/details/51398775

100%数据点:

对于每个子串,先对它排序,从主串中依次截取8位,如果这8位对应的字母个数 等于 子串的各个字母个数,说明匹配上(因为子串顺序可以任意排列的,对比字符出现的次数就能比较是否匹配),可以用哈希表优化查找
参考博客:https://blog.csdn.net/weixin_42765557/article/details/89402941

5.居民集会

10%数据点:

先想到暴力枚举,题目让我们找3个位置当作集会点,那我们就在1~l-1区间内枚举3个集会点,三重循环
参考博客:https://www.cnblogs.com/zhazhaacmer/p/9020089.html

上面博客的做法中,我们有两点我们可以在优化时用到:
1.前三个集合地点肯定是要建在某个人的家里,这样可能更加省时
2.前缀和预处理,sum[i] 表示 1号家庭 到距离起点i 之间 所有家庭到i集会的花费总和,那么sum[i] - sum[j] (j < i) 就可以算出 从j到i之间所有家庭到i集会的花费总和,我们可以在时间复杂度O(n)下完成预处理!

另外,如果没想到暴力枚举和预处理,我们可以用dfs搜索来做这10%的数据,我自己用dfs做的。先不放上代码。

10%-30%数据点:

分治 + 预处理时间复杂度O(l^2n),如果数据比较弱可以过30%数据
参考博客:https://blog.csdn.net/the_best_man/article/details/72472919
上面博客做法,值得参考的点:分治算法。具体怎么分治呢?题目让我们选3个位置当作集会点,也就等于让我们把1~L区域划分成4段,例如样例1~10,我们从1~10中划分4段即可。
缺点:预处理时间复杂度太高了O(l^2
n)

100%数据点:

上面博客做法的缺点:作者没有意识到前面我们说的 集会点在某个人家里更省时间,我们把作者的对距离1~L区间分治 改为对家庭1~n分治,再用前缀和预处理sum[i] 就可以完成
我不知道分治算法的时间复杂度怎么分析。。大概能过100%数据,如果过不了,当我没说。。

正常人的做法:DP动规,首先我认为这题和BZOJ 叶子合并 很像。
dp[i][j]表示前i个家庭建立了j个集会点时的最小花费, 自己想的状态转移方程:dp[i][j] = min(dp[i][j], dp[0~i-1][j-1] + sum[i] - sum[0~i-1]) 但是题目中数据n最大达到1e6,两层循环dp肯定不行,那怎么做呢。。我也不知道
 
 

6.模型染色

读不懂样例,不写了

 
 

2015年蓝桥杯B组C/C++决赛题解的更多相关文章

  1. 2018年蓝桥杯A组C/C++决赛题解

    2018年第九届蓝桥杯A组C/C++决赛题解 点击查看视频题解 点击查看2018年蓝桥杯A组C/C++决赛题目(不含答案) 1:三角形面积 画个图,求三角形面积,可以用外接长方形 - 其他多余区域面积 ...

  2. 2016年蓝桥杯B组C/C++决赛题解

    2016年第七届蓝桥杯B组C/C++决赛题解 2016年蓝桥杯B组C/C++决赛题目(不含答案) 1.一步之遥 枚举解方程,或者套模板解线性方程 #include<bits/stdc++.h&g ...

  3. 2018年蓝桥杯B组C/C++决赛题解

    2018年第九届蓝桥杯B组C/C++决赛题解 点击查看2018年蓝桥杯B组C/C++决赛题目(不含答案) 1.换零钞 ok 枚举 设x表示1元钱的个数,y表示2元钱的个数,z表示5元钱的个数 x+21 ...

  4. 2017年蓝桥杯B组C/C++决赛题解

    2017年蓝桥杯B组C/C++决赛题目(不含答案) 1.36进制 ok 求36进制,类比二进制转10进制,36^3 + 36^2 + 36^1 + 36^0 2.磁砖样式 ok dfs搜索 我自己写的 ...

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

    2015年第六届蓝桥杯B组C/C++国赛题目 点击查看2015年第六届蓝桥杯B组C/C++国赛题解     1.积分之迷 小明开了个网上商店,卖风铃.共有3个品牌:A,B,C. 为了促销,每件商品都会 ...

  6. 2018年蓝桥杯A组C/C++决赛题目

    2018年蓝桥杯A组C/C++决赛题目 2018年蓝桥杯A组C/C++决赛题解     1:三角形面积 已知三角形三个顶点在直角坐标系下的坐标分别为: (2.3, 2.5) (6.4, 3.1) (5 ...

  7. 2016年蓝桥杯B组C/C++决赛题目

    2016年第七届蓝桥杯B组C/C++决赛题目 点击查看2016年第七届蓝桥杯B组C/C++决赛题解 1.一步之遥 从昏迷中醒来,小明发现自己被关在X星球的废矿车里. 矿车停在平直的废弃的轨道上. 他的 ...

  8. 2017年蓝桥杯B组C/C++决赛题目

    2017年第八届蓝桥杯B组C/C++决赛题目 点击查看2017年蓝桥杯B组C/C++决赛题解     1.36进制 对于16进制,我们使用字母A-F来表示10及以上的数字. 如法炮制,一直用到字母Z, ...

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

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

随机推荐

  1. linux 系统下Anaconda的安装【安装python3.6环境首选】

    如果你不想使用python3.6的源码安装包,不想各种繁琐的配置命令,那Anacoda里边自带的python3.6环境就最合适不过了,下面来介绍下anacoda的安装过程,~so easy~Anaco ...

  2. 使用sessionStorage获取值和设置值

    <body><button id="btn1">设置值</button><button id="btn2">获取 ...

  3. AcWing 801. 二进制中1的个数

    网址 https://www.acwing.com/solution/AcWing/content/2066/ 题目描述给定一个长度为n的数列,请你求出数列中每个数的二进制表示中1的个数. 算法1主要 ...

  4. 将静态页面部署到github.io

    背景:   我的腾讯云服务器是之前利用学生身份(有优惠)买的,现在快到期了,而且服务器上面只有一个引导页(静态页面)还有用,别的项目都没有用了.所以就想找一种不花钱买服务器就可以访问到我的引导页的方法 ...

  5. Python爬虫大作业

    一.题目: 获取并保存目标网站的下图所示的所有英文名,网页转换通过点击more names刷新名字并将各个英文名子目录下,去获取并保存每一个英文名的名字.性别.寓意.简介如下图所示内容红色标记框内的内 ...

  6. 基于Docker的Consul服务发现集群搭建

    在去年的.NET Core微服务系列文章中,初步学习了一下Consul服务发现,总结了两篇文章.本次基于Docker部署的方式,以一个Demo示例来搭建一个Consul的示例集群,最后给出一个HA的架 ...

  7. linux--新装机图形化界面遇到的问题

    1 许可证信息 q 退出 c 继续 r 刷新 按以下顺序正确输入即可: 1  ------  2 -----  q  -----  yes

  8. es6入门7--Set Map数据结构

    本文作为ES6入门第十三章的学习整理笔记,可能会包含少部分个人的理解推测,若想阅读更详细的介绍,还请阅读原文ES6入门 一.set数据结构 1.set不接受重复值 ES6新增了Set构造函数用于创建s ...

  9. 解决centos下tomcat启动太慢 & JDBC连接oracle太慢的问题

    近期遇到一个非常奇怪的问题,也不知道改了什么,tomcat启动非常慢,以前几秒就启动好了,现在要30秒左右. 而且,通过jdbc连接oracle数据库也非常慢,以前建立一个连接只要几十毫秒,现在也要1 ...

  10. 前端框架Easyui学习积累

    前端框架Easyui学习积累 1.easyui textbox 赋值:$("#id").textbox("setValue","xx"); ...