第十二届蓝桥杯C++赛后感

文章目录

  • A 空间
  • 卡片
  • 直线
  • 货物摆放
  • 路径
  • 时间显示
  • G砝码称重
  • H杨辉三角形
  • 双向排列
  • J括号序列

注:有些代码忘了考试时怎么写的了,(我也懒得重新写),所以很多题的代码是acwing蓝桥杯讲解里的,我对其进行注释和修改

A 空间

在这里插入图片描述
32位程序中,INT变量占用4个字节
1mb=1024kb
1kb=1024B
1B=8b
B:byte
b:bit
32位二进制数是四个字节
实际上就是求256MB有多少个32 bit

答案:256*1024*1024/4
= 67108864

卡片

在这里插入图片描述
直接模拟即可

#include<bits/stdc++.h>
#define debug(a,b) printf("%s = %d\n",a,b)
typedef long long ll;
using namespace std;inline int read(){int s=0,w=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}while(ch>='0'&&ch<='9') s=s*10+ch-'0',ch=getchar();//s=(s<<3)+(s<<1)+(ch^48);return s*w;
}
int a[10];bool iff(int x) 
{while (x) {int y = x % 10;if (a[y])a[y]--;elsereturn 0;x /= 10;}return 1;
}int main() {for (int i = 0; i <= 9; i++) a[i] = 2021;for (int i = 1;; i++) {if (!iff(i)) {cout << i - 1 << endl;break;}}return 0;
}
答案:3181

直线

在这里插入图片描述
比赛时用set实现的,忘了自己做的对不对。。
我当时做的方法是因为两点确定一线,所以枚举两个点,然后用set记录斜率和截距(y=k*x+b),但是k有可能不存在,所以最后的答案还要额外加上20
当时代码懒得写了,按照其他博主的写法重新写的,只不过用的不是set,存下所有k和b后,排序,将重复的k和b删掉

#include<bits/stdc++.h>
#define debug(a,b) printf("%s = %d\n",a,b)
typedef long long ll;
using namespace std;inline int read(){int s=0,w=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}while(ch>='0'&&ch<='9') s=s*10+ch-'0',ch=getchar();//s=(s<<3)+(s<<1)+(ch^48);return s*w;
}
const int maxn = 200000;
double eps=1e-8;
int n;
struct Line
{double k, b;bool operator< (const Line& t) const{if (k != t.k) return k < t.k;return b < t.b;}
}L[maxn];int main()
{for (int x1 = 0; x1 < 20; x1 ++ )for (int y1 = 0; y1 < 21; y1 ++ )for (int x2 = 0; x2 < 20; x2 ++ )for (int y2 = 0; y2 < 21; y2 ++ )if (x1 != x2){double k = (double)(y2 - y1) / (x2 - x1);double b = y1 - k * x1;L[n ++ ] = {k, b};//存两点所形成的直线 }sort(L, L +maxn);int res = 1;for (int i = 1; i < n; i ++ )if (fabs(L[i].k - L[i - 1].k) > eps || fabs(L[i].b - L[i - 1].b) > eps)//说明不是一条直线 res ++ ;cout << res + 20 << endl;//加20是因为k不存在的直线也要考虑 return 0;
}

我当时的做法是对的,但是最后的答案忘了是不是这个

答案:40257

货物摆放

在这里插入图片描述
LWH都是n的约数,问有多少种方案,其实就是求n的约数,用这些约数进行组合。因为约数不是很多,所以三重循环枚举约数,看是否等于n
对n求约束,直接开方求就行(因为如果x是约数,那么n/x也是,所以只需要将范围缩小到根号n)
(比赛时我是这么做的,确信)

#include <iostream>
#include <cstring>
#include <algorithm>
#include <vector>using namespace std;typedef long long LL;int main()
{LL n;cin >> n;vector<LL> d;for (LL i = 1; i * i <= n; i ++ )if (n % i == 0){d.push_back(i);if (n / i != i) d.push_back(n / i);}int res = 0;for (auto a: d)for (auto b: d)for (auto c: d)if (a * b * c == n)res ++ ;cout << res << endl;return 0;
}
答案:2430

路径

在这里插入图片描述
就是一个建边跑最短路。。比赛时忘了gcd咋写emm
好像有的用dp来做?

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;const int N = 2200, M = N * 50;int n;
int h[N], e[M], w[M], ne[M], idx;
int q[N], dist[N];
bool st[N];int gcd(int a, int b)  // 欧几里得算法
{return b ? gcd(b, a % b) : a;
}void add(int a, int b, int c)  // 添加一条边a->b,边权为c
{e[idx] = b, w[idx] = c, ne[idx] = h[a], h[a] = idx ++ ;
}void spfa()  // 求1号点到n号点的最短路距离
{int hh = 0, tt = 0;memset(dist, 0x3f, sizeof dist);dist[1] = 0;q[tt ++ ] = 1;st[1] = true;while (hh != tt){int t = q[hh ++ ];if (hh == N) hh = 0;st[t] = false;for (int i = h[t]; i != -1; i = ne[i]){int j = e[i];if (dist[j] > dist[t] + w[i]){dist[j] = dist[t] + w[i];if (!st[j])     // 如果队列中已存在j,则不需要将j重复插入{q[tt ++ ] = j;if (tt == N) tt = 0;st[j] = true;}}}}
}int main()
{n = 2021;memset(h, -1, sizeof h);for (int i = 1; i <= n; i ++ )for (int j = max(1, i - 21); j <= min(n, i + 21); j ++ ){int d = gcd(i, j);add(i, j, i * j / d);}spfa();printf("%d\n", dist[n]);return 0;
}
答案:10266837

时间显示

在这里插入图片描述
比赛时忘了1s等于多少ms,还好电脑自带计算器里有时间的进制关系(狗头🐕)

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;typedef long long LL;int main()
{LL n;cin >> n;n /= 1000;n %= 86400;int h = n / 3600;n %= 3600;int m = n / 60;int s = n % 60;printf("%02d:%02d:%02d\n", h, m, s);return 0;
}

G砝码称重

在这里插入图片描述
背包问题
自己对dp真的不熟。。五一要好好练练dp
在这里插入图片描述
对于每个砝码他有三个选择,称的左侧,右侧和不放,
我们设dp[i][j]表示前i个物品中,总质量为j的情况是否存在,dp为bool型
对于第j个物品,我们说了有三种选择,所以我们可以得到转移方程:

分别对应不选,放左侧,放右侧
dp[i][j]|=dp[i-1][j]
dp[i][j]|=dp[i-1][j-w[i]]
dp[i][j]|=dp[i-1][j+w[i]]

按照题目要求j-w[i]最小为-m,数组不能用负下标,所以我们加一个偏移量B,保证数组下标都为非负

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;const int N = 110, M = 200010, B = M / 2;int n, m;
int w[N];
bool f[N][M];int main()
{scanf("%d", &n);for (int i = 1; i <= n; i ++ ) scanf("%d", &w[i]), m += w[i];f[0][B] = true;for (int i = 1; i <= n; i ++ )for (int j = -m; j <= m; j ++ ){f[i][j + B] = f[i - 1][j + B];if (j - w[i] >= -m) f[i][j + B] |= f[i - 1][j - w[i] + B];if (j + w[i] <= m) f[i][j + B] |= f[i - 1][j + w[i] + B];}int res = 0;for (int j = 1; j <= m; j ++ )if (f[n][j + B])res ++ ;printf("%d\n", res);return 0;
}

H杨辉三角形

在这里插入图片描述
在这里插入图片描述
因为杨辉三角形左右对称,所以我们只考虑左半部分
我们进行枚举可以看出,斜列的数量不会超过20个,所以枚举每一个斜列,每个斜列的第一个元素也是递增排列且有关系(第一个斜列的首元素为C(1,0),第二个为C(1,2),第三个为C(2,4),…C(x,2x)),斜列内的元素是递增排列的,且大小都有公式关系(比如第3个斜列,第一个元素是C(2,4),第二个元素是C(2,5),然后是C(2,6)…),然后二分找具体位置
如果第C(r,k)是我们要找的元素,他的位置就是r * (r + 1) / 2 + k + 1
思维题
妙啊,当时写了一个半暴力,真想不到

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;typedef long long LL;int n;LL C(int a, int b)
{LL res = 1;for (int i = a, j = 1; j <= b; i --, j ++ ){res = res * i / j;if (res > n) return res;}return res;
}bool check(int k)
{//C(a,b)//a>=2b,二分a LL l = k * 2, r = n;while (l < r){LL mid = l + r >> 1;if (C(mid, k) >= n) r = mid;else l = mid + 1;}if (C(r, k) != n) return false;cout << r * (r + 1) / 2 + k + 1 << endl;return true;
}int main()
{cin >> n;for (int k = 16; ; k -- )if (check(k))break;return 0;
}

双向排列

讲解链接

J括号序列

在这里插入图片描述
肯定是dp,但是我不会。。。等会了再更新

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/317566.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SeaweedFS在.net core下的实践方案

一直对分布式的文件储存系统很感兴趣&#xff0c;最开始关注淘宝的TFS&#xff08;Taobao File System&#xff09;&#xff0c;好像搁浅了&#xff0c;官方地址无法访问&#xff0c;github上面&#xff0c;各种编译问题&#xff0c;无意间发现了SeaweedFS链接seaweedfs测试了一…

[C++ STL algorithm] lower_bound、upper_bound、unique的本质

lower_bound&#xff1a;返回第一个大于等于查找值的地址upper_bound&#xff1a;返回第一个严格大于查找值的地址 使用这两个函数需要的头文件 #include <algorithm> using namespace std;要求数组必须是有序/单调的 lower_bound lower_bound( a 1, a n 1, x );意…

蓝桥杯 I.双向排序

题目链接 题解&#xff1a; 比赛时就直接写了一个暴力sort交上&#xff0c;能骗一点分是一点 昨晚看了acwing的讲解&#xff0c;现在结合我的思路更新正解 题目中设计两个操作&#xff0c;一个是选定前x个数&#xff0c;使其降序&#xff0c;另一个是选定后y个数&#xff0c…

微软收购Citus Data | 再次肯定对开源的承诺,并加速了Azure PostgreSQL的性能和扩展...

作者&#xff1a;Rohan Kumar 翻译&#xff1a;周宝峰 从左到右&#xff1a;微软开源关系数据库总经理Sudhakar Sannakkayala&#xff0c;Citus Data首席技术官兼联合创始人Ozgun Erdogan&#xff0c;Citus Data首席执行官兼联合创始人Umur Cubukcu&#xff0c;Citus Data工…

Docker最全教程——MongoDB容器化(十三)

上一节我们讲述了数据库容器化之持久保存数据&#xff0c;本节将讲诉MongoDB容器化实践&#xff0c;并且接下来将逐步讲解其他数据库&#xff08;MySql、Redis等等&#xff09;的容器化实践&#xff0c;然后将讲诉一些分布式架构的项目实践。由于实践需要花费大量的时间&#x…

在.NET Core中使用Exceptionless分布式日志收集框架

一.Exceptionless简介Exceptionless 是一个开源的实时的日志收集框架&#xff0c;它可以应用在基于 ASP.NET&#xff0c;ASP.NET Core&#xff0c;Web Api&#xff0c;Web Forms&#xff0c;WPF&#xff0c;Console&#xff0c;MVC 等技术栈的应用程序中&#xff0c;并且提供了…

test1 3-15 模拟赛1

文章目录考试复盘matrixsetstring考试复盘 首先先说T1T1T1&#xff0c;嗯&#xff0c;发现了列是相互独立的&#xff0c;所以分开考虑了 但是实在没想到线性基&#xff0c;就顺着自己的思路硬搞了505050跑路 老实说&#xff0c;505050分的部分分写得都是迷迷糊糊的&#xff0c;…

华为云提供针对Nuget包管理器的缓存加速服务测试

在Visual Studio 2013、2015、2017中&#xff0c;使用的是Nuget包管理器对第三方组件进行管理升级的。而且 Nuget 是我们使用.NET Core的一项基础设施&#xff0c;.NET的软件包管理器NuGet.org是一项面向全球用户搭建的服务&#xff0c;不论用户身在何处&#xff0c;NuGet.org都…

test2 3-16 2021 模拟赛two

文章目录考试复盘染色问题芬威克树礼物考试复盘 先说T1T1T1 染色&#xff0c;以为是道数学题&#xff0c;推了有一会儿的公式&#xff0c;从颜色1到颜色m&#xff0c;感觉是dpdpdp转移 发现颜色重叠的方案可以转化为另外一种相邻不重叠的染色 但是推到颜色4的时候就发现自己…

ASP.NET Core 2.2 : 扒一扒新的Endpoint路由方案

ASP.NET Core 从2.2版本开始&#xff0c;采用了一个新的名为Endpoint的路由方案&#xff0c;与原来的方案在使用上差别不大&#xff0c;但从内部运行方式上来说&#xff0c;差别还是很大的。上一篇ASP.NET Core;图解路由(2.1 earler)详细介绍了原版路由方案的运行机制&#xff…

开源中国 2018 新增开源软件最受欢迎 TOP 50

本周开源中国陆续公布了两个年度榜单&#xff0c;分别是国产新秀榜 TOP 30 和国产新增榜 TOP 50。由于两个榜单的数据来源都是国内开源项目&#xff0c;所以会有部分项目同时出现在两个榜单上。今天公布的这份榜单 —— 开源中国 2018 新增开源软件最受欢迎 TOP 50&#xff0c;…

[树链剖分]List wants to travel,Relief grain,hotel加强版,This world need more Zhu

文章目录B&#xff1a;Relief grainC&#xff1a;hotel加强版B&#xff1a;Relief grain 题目 将一段区间修改的标记变成差分&#xff0c;每次都是连续一段的dfndfndfn序修改 从小到大枚举dfndfndfn&#xff0c;在一段标记的最开头的dfndfndfn插入&#xff0c;最末尾的dfndf…

eShopOnContainers 知多少[8]:Ordering microservice

1. 引言Ordering microservice&#xff08;订单微服务&#xff09;就是处理订单的了&#xff0c;它与前面讲到的几个微服务相比要复杂的多。主要涉及以下业务逻辑&#xff1a;订单的创建、取消、支付、发货库存的扣减2. 架构模式如上图所示&#xff0c;该服务基于CQRS 和DDD来实…

[翻译] Entity Framework Core in Action 关于这本书

Entityframework Core in action是 Jon P smith 所著的关于Entityframework Core 书籍。原版地址. 是除了官方文档外另一个学习EF Core的不错途径, 书中由浅入深的讲解的EF Core的相关知识。因为没有中文版,所以本人对其进行翻译。 预计每两天一篇更新 PS: 翻译难免限于本人水平…

NC51189 Mondriaan‘s Dream

NC51189 Mondriaan’s Dream 题意&#xff1a; n * m的矩阵&#xff0c;用1 * 2和2 * 1的砖快密铺&#xff0c;问多少种方法&#xff1a; 题解&#xff1a; 方法1&#xff1a; 我们现在规定砖头的竖放的上部分为1&#xff0c;砖头的横放或者是竖放的下部分为0 我们每两层进…

《小团队构建大网站:中小研发团队架构实践》送书活动结果公布

截止到1月25日24&#xff1a;00&#xff0c;本次送书活动共收到75位同学参与回复&#xff0c;本次很多同学在看到活动的书十年IT老兵带你通过案例学架构&#xff0c;附C#代码&#xff0c;自行就到各大网络商店上购买了书&#xff0c;据反馈这个书很不错.下面把Top 2的留言截图给…

test6 3-21 2021省选模拟赛six

文章目录考试复盘rnglgpm考试复盘 第一题&#xff0c;乍一看期望&#xff0c;又不会做了&#xff0c;乍二看&#xff0c;暴力好像可以202020跑路&#xff0c;屁颠屁颠敲完死活过不了这个简单的样例&#xff1b;开始(⊙⊙?)乍三看&#xff0c;实数&#xff1f;&#xff1f;完了…

如何为 .NET Core CLI 启用 TAB 自动补全功能

Intro在 Linux 下经常可以发现有些目录/文件名&#xff0c;以及有些工具可以命令输入几个字母之后按 TAB 自动补全&#xff0c;最近发现其实 dotnet cli 也可以&#xff0c;从.NET Core 2.0 SDK 开始&#xff0c;NET Core CLI 支持 tab 自动补全。你如果已经装了 dotnet Core S…

P8215-[THUPC2022 初赛]分组作业【网络流】

正题 题目链接:https://www.luogu.com.cn/problem/P8215 题目大意 有2n2\times n2n个人&#xff0c;第2i−12\times i-12i−1和第2i2\times i2i个人一组&#xff0c;然后每个人可以选择愿不愿意合作&#xff0c;愿意需要付出cic_ici​代价&#xff0c;不愿意是did_idi​代价&…

.NET IdentityServer4实战-开篇介绍与规划

一.开篇寄语由于假期的无聊&#xff0c;我决定了一个非常有挑战性的活动&#xff0c;也就是在年假给大家带来一个基于OAuth 2.0的身份授权框架&#xff0c;它就是 IdentityServer4 &#xff0c;如果没有意外的话&#xff0c;一定可以顺利的写完的&#xff0c;如果两天写一篇的话…