蓝桥·算法双周赛|第七场分级赛——小白入门赛

在这里插入图片描述

🔥博客介绍`: 27dCnc

🎥系列专栏: <<数据结构与算法>> << 算法入门>> << C++项目>>

🎥 当前专栏: << 算法入门>>

专题 : 数据结构帮助小白快速入门算法
👍👍👍👍👍👍👍👍👍👍👍👍
☆*: .。. o(≧▽≦)o .。.:*☆

❤️感谢大家点赞👍收藏⭐评论✍️

在这里插入图片描述

学习目标:

今日学习打卡
在这里插入图片描述

  • ACM题解

学习时间:

  • 周一至周五晚上 7 点—晚上9点
  • 周六上午 9 点-上午 11 点
  • 周日下午 3 点-下午 6 点

赛题:

在这里插入图片描述


内容详细:

thanks,mom【算法赛】

题目考点: 语言题

在这里插入图片描述

解题思路: 直接输出

易错点,注意输出格式: thanks, 后面有个空格

代码

#include <iostream>
using namespace std;
int main()
{std::cout << "thanks, mom";return 0;
}

霓虹【算法赛】

题目考点: 思维 数组表示状态

在这里插入图片描述

思路:

用 0 和 1 表示每个数的开关状态,然后以没有变化前和变化后的数为下标去查询比较状态,最后得出答案

代码

#include <iostream>
using namespace std;
using ll = long long;void solve(string s,string t) {int a[7][10] = {{1,0,1,1,0,1,1,1,1,1},{1,1,1,1,1,0,0,1,1,1},{1,1,0,1,1,1,1,1,1,1},{1,0,1,1,0,1,1,0,1,1},{1,0,1,0,0,0,1,0,1,0},{1,0,0,0,1,1,1,0,1,1},{0,0,1,1,1,1,1,0,1,1}};ll ans = 0;for (int i = 0; i < s.size(); i++) {if(s[i] != t[i]) {for (int j = 0; j < 7; j++) {if (a[j][s[i] - '0'] != a[j][t[i] - '0']) ans++;}}}std::cout << ans << endl;
}int main()
{string s,T;std::cin >> s >> T;solve(s,T);return 0;
}

奇偶排序【算法赛】

题目考点: 自定义排序 思维

223
解题思路

  1. sort() 中的自定义排序规则
  2. 根据题目要求偶数一定在奇数后面然后我们将元素区分奇偶,分别进行排序然后分别打印得到答案

代码

#include<bits/stdc++.h>
using namespace std;bool cmp(int a,int b) {if ((a % 2 == 0 && b % 2 == 0) || (a % 2 != 0 && b % 2 != 0)) {return a < b;} else {if (a % 2 == 0) {return false;} else {return true;}}
}int main()
{int n; std::cin >> n;std::vector<int>ans(n);for (int i = 0; i < n; i++) {std::cin >> ans[i];}sort(ans.begin(),ans.end(),cmp);for (int i = 0; i < n; i++) {std::cout << ans[i] << " ";}return 0;
}

可结合的元素对【算法赛】

题目考点: lowbit

在这里插入图片描述

暴力解法:超时

#include <bits/stdc++.h>
using namespace std;
using ll = long long;int lowbit(int a) {return (a) & -(a);
}int main()
{int n; std::cin >> n;std::vector<int>ans(n + 10);for (int i = 1; i <= n; i++) {std::cin >> ans[i];}ll ANS = 0;for (int i = 1; i <= n; i++) {for (int j = i + 1; j <= n; j++) { if ((lowbit(ans[i] + ans[j])) == (ans[i] + ans[j])) ANS++;}}std::cout << ANS << std::endl;return 0;
}

最终解法: 暂时没有理解

#include<bits/stdc++.h>
#define int long long
using namespace std;int a[100010];
unordered_map<int,int> h;signed main()
{int n;cin>>n;for(int i=1;i<=n;i++)cin>>a[i];sort(a+1,a+n+1);int res=0;for(int i=1;i<=n;i++){for(int k=1;k<=30;k++)//枚举所有可能的k{int aj=(1<<k)-a[i];//aj为能与a[i]配对的数if(h.find(aj)!=h.end())res+=h[aj];//能找到aj}h[a[i]]++;}cout<<res;return 0;
}

兽之泪【算法赛】

题目考点: 优先队列

在这里插入图片描述

解题思路:我尚未理解清楚
在这里插入图片描述

代码

#include <bits/stdc++.h>
using namespace std;
#define int long long
using Pair=pair<int,int>;
const int N=2e5+9;
int a[N];
int b[N];
set<int>s;
priority_queue<Pair,vector<Pair>,greater<Pair>>pq;signed  main()
{int n,k;cin>>n>>k;int t=k;for(int i=1;i<=n;i++){cin>>a[i]>>b[i];if(i<=n-1)pq.push({a[i],i});}int ans=0,id;while(t--){if(s.size()==n-1)pq.push({a[n],n});ans+=pq.top().first;id=pq.top().second;int t=id;s.insert(id);pq.pop();pq.push({b[id],id});}int res=0;int mn=INT_MAX;for(int i=1;i<=n;i++){res+=a[i];mn=min(mn,b[i]);}res+=(k-n)*mn;cout<<min(ans,res);return 0;
}

矩阵X【算法赛】

题目考点: 思维 队列 数组 滑动窗口 二维前缀和

在这里插入图片描述
代码

#include <iostream>
#include <vector>
#include <queue>
using namespace std;
int n,m;
int np,mp;
long long ans;
int main()
{cin>>n>>m;cin>>np>>mp;bool flag=false;if(n>m)swap(n,m),swap(np,mp),flag=true;vector<vector<int>> v(n+1,vector<int>(m+1));vector<vector<long long>> sum(n+1,vector<long long>(m+1));vector<vector<int>> maxn(n+1,vector<int>(m+1));vector<vector<int>> minn(n+1,vector<int>(m+1));if(flag==false){for(int i=1;i<=n;++i)for(int j=1;j<=m;++j)cin>>v[i][j];}else{for(int i=1;i<=m;++i)for(int j=1;j<=n;++j)cin>>v[j][i];}for(int i=1;i<=n;++i){for(int j=1;j<=m;++j){sum[i][j]=sum[i-1][j]+sum[i][j-1]-sum[i-1][j-1]+v[i][j];}}queue<int> q;for(int i=1;i<=n;++i){while(!q.empty())q.pop();for(int j=1;j<=m;++j){while(!q.empty()&&q.front()+mp<=j)q.pop();while(!q.empty()&&v[i][j]>v[i][q.front()])q.pop();q.push(j);if(j-mp+1>=1)maxn[i][j-mp+1]=v[i][q.front()];}}for(int i=1;i<=n;++i){while(!q.empty())q.pop();for(int j=1;j<=m;++j){while(!q.empty()&&q.front()+mp<=j)q.pop();while(!q.empty()&&v[i][j]<v[i][q.front()])q.pop();q.push(j);if(j-mp+1>=1)minn[i][j-mp+1]=v[i][q.front()];//cout<<minn[i][j-mp+1]<<' ';}//cout<<endl;}for(int i=1;i<=n-np+1;++i){for(int j=1;j<=m-mp+1;++j){for(int k=i;k<=i+np-1;++k){maxn[i][j]=max(maxn[i][j],maxn[k][j]);minn[i][j]=min(minn[i][j],minn[k][j]);}//cout<<maxn[i][j]<<' '<<minn[i][j]<<' ';long long temp=sum[i+np-1][j+mp-1]-sum[i-1][j+mp-1]-sum[i+np-1][j-1]+sum[i-1][j-1];ans=max(ans,temp*(maxn[i][j]-minn[i][j]));}//cout<<endl;}cout<<ans<<endl;
}

学习产出:

  • 技术笔记 2 遍
  • CSDN 技术博客 3 篇
  • 习的 vlog 视频 1 个

在这里插入图片描述

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

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

相关文章

C#四部曲(知识补充)

Unity跨平台原理 .Net相关 只要编写的时候遵循.NET的这些规则&#xff0c;就能在.NET平台下通用 各种源码→根据.NET规范编写→(虚拟机)生成CIL中间码(保存在程序集中)→转成操作系统原代码 跨语言← 跨平台↓ Unity跨平台原理&#xff08;Mono&#xff09; c#脚本→MonoC#编…

CCCorelib 点云曲面特征(CloudCompare内置算法库)

文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 这里基于每个点的邻域协方差来获取点云中具有的曲面几何特征的点,计算方式如下图所示: 二、实现代码 // CloudCompare #include <CCCoreLib/PointCloudTpl.h> #include <CCCoreLib/

使用 PlayFab 服务器托管的 5 个步骤

在本教程中,你将了解如何使用 Unity、镜像网络和 PlayFab 服务器托管来构建在线多人游戏。玩家不能再位于同一个本地网络上。他们将连接到托管在云中的专用服务器,这使得他们即使相距很远也可以一起玩。 架构概述 下图显示了我们将构建的架构。 玩家将使用他们的客户端并连…

2024年G3锅炉水处理证模拟考试题库及G3锅炉水处理理论考试试题

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2024年G3锅炉水处理证模拟考试题库及G3锅炉水处理理论考试试题是由安全生产模拟考试一点通提供&#xff0c;G3锅炉水处理证模拟考试题库是根据G3锅炉水处理最新版教材&#xff0c;G3锅炉水处理大纲整理而成&#xff0…

读算法的陷阱:超级平台、算法垄断与场景欺骗笔记08_行为歧视

1. 常见的报价方式 1.1. 水滴定价&#xff08;Drip Pricing&#xff09; 1.1.1. 用一个较低的初始价格吸引消费者入局&#xff0c;之后再不断收取附加费用 1.2. 打折促销 1.2.1. 在一个远被高估的原价上制造折扣价格的魅力 1.2…

Hive面经

hive原理 Hive 内部表和外部表的区别Hive 有索引吗运维如何对 Hive 进行调度ORC、Parquet 等列式存储的优点数据建模用的哪些模型&#xff1f;1. 星型模型2. 雪花模型3. 星座模型 为什么要对数据仓库分层&#xff1f;使用过 Hive 解析 JSON 串吗sort by 和 order by 的区别数据…

自动化运维工具Ansible

一.Ansible基本内容 1.定义 Ansible是基于模块工作的&#xff0c;只是提供了一种运行框架&#xff0c;本身没有完成任务的能力&#xff0c;真正操作的是Anisble的模块。每个模块都是独立的、实现了批量系统配置、批量程序部署、批量运行命令等功能。 2.特点与优势 优势&…

【Python爬虫神器揭秘】手把手教你安装配置Scrapy,高效抓取网络数据

1、 引言 在大数据时代&#xff0c;网络上的信息犹如海洋般浩瀚。想要在这片海洋里挖掘宝藏&#xff0c;一款强大的工具必不可少。今天我们要带大家深入探索的就是Python界鼎鼎大名的爬虫框架——Scrapy。无论你是数据分析师、研究员还是开发者&#xff0c;学会利用Scrapy来自…

基于单片机的IC 卡门禁系统设计

摘要:针对传统门锁钥匙易丢失、配置不便和忘记携带等问题,提出了一种基于STC89C52 的IC 卡门禁系统设计。该系统以STC89C52 单片机为核心来控制电子锁模块的开关。主要过程是由RFID 模块读取IC卡ID 并通过串口发送至STC89C52 单片机模块,STC89C52 单片机模块可以实现在线对I…

如果电脑缺少dll文件怎么解决?如何快速解决dll丢失问题

最近有小伙伴问电脑老是缺少dll文件&#xff0c;这种问题到底要怎么去解决呢&#xff1f;其实这种现象是正常的&#xff0c;为啥说正常呢&#xff0c;下面我们会给大家详细的讲解dll为啥会缺少&#xff0c;然后还会讲解电脑缺少dll文件怎么解决的方法&#xff0c;好了&#xff…

ARM学习(25)链接装载高阶认识

ARM学习&#xff08;25&#xff09;链接装载高阶认识 1、例子引出 笔者先引入几个编译链接的例子来介绍一下&#xff1a; 声明无效&#xff1a;declared implicitly&#xff1f;&#xff0c;属于编译错误还是链接错误&#xff1f; 编译阶段的错误&#xff0c;属于编译错误&am…

【DDR】DDR4学习记录

这里以美光DDR4芯片 MT40A512M16HA-075E datasheet 为例&#xff0c;说明DDR4存储器的原理及仿真。   根据开发板手册ug1302&#xff0c;在vcu128&#xff08;xcvu37p&#xff09;开发板上&#xff0c;共具有5块DDR4芯片&#xff0c;在数据信号上4块DDR4具有16位数据线&#…

七月论文审稿GPT第3.1版和第3.2版:通过paper-review数据集分别微调Mistral、gemma

前言 我司第二项目组一直在迭代论文审稿GPT(对应的第二项目组成员除我之外&#xff0c;包括&#xff1a;阿荀、阿李、鸿飞、文弱等人)&#xff0c;比如 七月论文审稿GPT第1版&#xff1a;通过3万多篇paper和10多万的review数据微调RWKV七月论文审稿GPT第2版&#xff1a;用一万…

Scrapy 爬虫框架

网络爬虫框架scrapy &#xff08;配置型爬虫&#xff09; 什么是爬虫框架&#xff1f; 爬虫框架是实现爬虫功能的一个软件结构和功能组件集合爬虫框架是个半成品&#xff0c;帮助用户实现专业网络爬虫 scrapy框架结构("52"结构) spider: 解析downloader返回的响…

第四弹:Flutter图形渲染性能

目标&#xff1a; 1&#xff09;Flutter图形渲染性能能够媲美原生&#xff1f; 2&#xff09;Flutter性能优于React Native? 一、Flutter图形渲染原理 1.1 Flutter图形渲染原理 Flutter直接调用Skia 1&#xff09;Flutter将一帧录制成SkPicture&#xff08;skp&#xff…

Doris部署学习(一)

目录 前言 一、Docker容器支持 二、Doris编译步骤 1.拉取镜像 2.构建Docker编译容器 3.下载源码并编译 前言 本文档主要介绍如何通过源码在Docker编译 Doris&#xff0c;以及部署。 一、Docker容器支持 Docker教程&#xff1a;Docker & Docker-Compose 安装教程 - 知…

jupyter 修改文件保存位置 步骤

一、找到配置文件位置 打开Anaconda Prompt&#xff0c;输入&#xff1a; jupyter notebook --generate-config 根据得到的路径&#xff0c;以记事本方式打开配置文件 二、修改路径 在文件中输入&#xff1a; c.NotebookApp.notebook_dir E:\\deepLearning\\Jupyter_files…

Vue的渲染原理

列表渲染 列表渲染 v-for指令写在循环项上&#xff1a;v-for“(一个参数或者两个参数) in/of 要遍历的数组、对象、字符串、指定次数” 遍历数组时参数分别是数组中元素(可以是一个对象)和元素所在下标(从0开始)遍历对象时参数分别是属性值和属性名遍历字符串时参数分别是单…

人工智能在增强数据安全方面的作用

近年来&#xff0c;人工智能&#xff08;AI&#xff09;的力量已被证明是无与伦比的。它不再是我们想象的主题。人工智能已经成为现实&#xff0c;并且越来越清楚地表明它可以让世界变得更美好。但人工智能能帮助我们增强数据安全吗&#xff1f; 由于技术的日益普及&#xff0…

概率与常见的概率分布

概率是数据分析、机器学习中最基础的知识。也是在生活中最实用的一门学科&#xff0c;学了很多大道理不一定能过好一生&#xff0c;学好概率则有一定概率会变得更好。为大概率坚持&#xff0c;为小概率备份。 概率与分布 要想了解概率&#xff0c;首先得搞清楚概率和概率分布的…