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

news2024/12/25 12:41:24

在这里插入图片描述

🔥博客介绍`: 27dCnc

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

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

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

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

在这里插入图片描述

学习目标:

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

  • ACM题解

学习时间:

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

赛题:

在这里插入图片描述

  1. 搭建 Java 开发环境
  2. 掌握 Java 基本语法
  3. 掌握条件语句
  4. 掌握循环语句

内容详细:

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.coloradmin.cn/o/1509791.html

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

相关文章

【全志H616】1 --用orangepi控制硬件

【全志H616】1 --用orangepi控制硬件 本文介绍了如歌用orangepi 控制蜂鸣器&超声波模块&#xff0c;通过键盘输入1、2、3、4来控制转动角度舵机模块&#xff1b;同时还介绍了利用全志如何配置定时器&#xff1b;以及查看H616引脚状态的命令等… 超声波模块和舵机模块的讲解…

Python递归函数你用对了吗?

1.递归函数 递归函数&#xff1a;函数自己调用自己 2.需求 使用函数的方式&#xff0c;计算数字n的阶乘 # 5&#xff01; """ 5! 1 * 2 * 3 * 4 * 5 4! 1 * 2 * 3 * 4 3! 1 * 2 * 3 2! 1 * 2 1! 1综上可以总结出&#xff1a;n! n * (n - 1) "&qu…

案例分析篇02:软件架构设计考点之特定领域软件架构、架构评估、架构视图(2024年软考高级系统架构设计师冲刺知识点总结)

专栏系列文章推荐: 2024高级系统架构设计师备考资料(高频考点&真题&经验)https://blog.csdn.net/seeker1994/category_12593400.html 【历年案例分析真题考点汇总】与【专栏文章案例分析高频考点目录】(2024年软考高级系统架构设计师冲刺知识点总结-案例分析篇-…

鼠标在QTreeView、QTableView、QTableWidget项上移动,背景色改变

目录 1. 前言 2. 需求 3. 功能实现 3.1. 代码实现 3.2. 功能讲解 4. 附录 1. 前言 本博文用到了Qt的model/view framework框架,如果对Qt的“模型/视图/委托”框架不懂&#xff0c;本博文很难读懂。如果不懂这方面的知识&#xff0c;请在Qt Assistant 中输入Model/View…

[iOS]高版本MacOS运行低版本Xcode

Xcode 版本支持文档 目的&#xff1a; 在MacOS Sonoma 系统上安装 Xcode14.3.1 第一步 先在Xcode下载一个Xcode14.3.1的压缩包 第二步 本地解压Xcode&#xff0c;将外层目录名变更为Xcode_14.3.1&#xff0c;将文件拷贝到 /Applications目录下。 第三步 变更xcode-sel…

Docker基础教程 - 12 常用容器部署-Nginx

更好的阅读体验&#xff1a;点这里 &#xff08; www.doubibiji.com &#xff09; 12 常用容器部署-Nginx 下面介绍一下常用容器的部署。可以先简单了解下&#xff0c;用到再来详细查看。 在 Docker 中部署 Nginx&#xff0c;并通过挂载方式将 Nginx 的配置文件和站点目录挂…

leecode算法二

滑动窗口/双指针 滑动窗口 得到K个黑块的最少涂色次数 滑动窗口法 方法一 方法二 水果成篮 二叉树 概念 中序遍历 前序遍历和后序遍历无非就是把result.add房价加在前面和后面。 层序遍历 广度优先算法 深度优先算法 线段树 我的日程安排表II

Day36:安全开发-JavaEE应用第三方组件Log4j日志FastJson序列化JNDI注入

目录 Java-项目管理-工具配置 Java-三方组件-Log4J&JNDI Java-三方组件-FastJson&反射 思维导图 Java知识点&#xff1a; 功能&#xff1a;数据库操作&#xff0c;文件操作&#xff0c;序列化数据&#xff0c;身份验证&#xff0c;框架开发&#xff0c;第三方库使用…

[Unity3D]--更换天空盒子

我们原来的天空盒子是这样的。 感觉不是特别满意&#xff0c;想换一个更好看的。 去资源商店找个好看的 外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传 例如这个 然后在Window>Rendering>Lighting里的环境选项里更换材质 更换&#xff1a; ​ …

SpringBoot注解--08--注解@JsonInclude

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 JsonInclude注解是jackSon中最常用的注解之一&#xff0c;是为实体类在接口序列化返回值时增加规则的注解 1.JsonInclude用法2.JsonInclude注解中的规则有 案例需求…

卷积神经网络CNN(一篇文章 理解)

目录 一、引言 二、CNN算法概述 1 卷积层 2 池化层 3 全连接层 三、CNN算法原理 1 前向传播 2 反向传播 四、CNN算法应用 1 图像分类 2 目标检测 3 人脸识别 六、CNN的优缺点 优点&#xff1a; 1 特征提取能力强 2 平移不变性 3 参数共享 4 层次化表示 缺点…

机器学习-04-分类算法-01决策树案例

总结 本系列是机器学习课程的系列课程&#xff0c;主要介绍机器学习中分类算法&#xff0c;本篇为分类算法开篇与决策树部分。 本门课程的目标 完成一个特定行业的算法应用全过程&#xff1a; 懂业务会选择合适的算法数据处理算法训练算法调优算法融合 算法评估持续调优工程…

一次因PageHelper引起的多线程复用问题的排查和解决方案

目录导航 导读01.Problem Description02.Problem inspection Steps1. Code Review2. Log Check and Prove 03.Analysis Steps1. How to use PageHelpera. Github Official Document Linkb. Analysis Source Code of PageHelper 2. How to solve the problem 导读 本文不仅对遇…

作用域链的理解(超级详细)

文章目录 一、作用域全局作用域函数作用域块级作用域 二、词法作用域三、作用域链 一、作用域 作用域&#xff0c;即变量&#xff08;变量作用域又称上下文&#xff09;和函数生效&#xff08;能被访问&#xff09;的区域或集合 换句话说&#xff0c;作用域决定了代码区块中变…

狂飙Linux平台,PostgreSQL16部署大全

&#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; 哈喽&#xff01;大家好&#xff0c;我是【IT邦德】&#xff0c;江湖人称jeames007&#xff0c;10余年DBA及大数据工作经验 一位上进心十足的【大数据领域博主】&#xff01;&#x1f61c;&am…

生成式 AI:使用 Pytorch 通过 GAN 生成合成数据

导 读 生成对抗网络&#xff08;GAN&#xff09;因其生成图像的能力而变得非常受欢迎&#xff0c;而语言模型&#xff08;例如 ChatGPT&#xff09;在各个领域的使用也越来越多。这些 GAN 模型可以说是人工智能/机器学习目前主流的原因&#xff1b; 因为它向每个人&#xff0…

vue+elementUI用户修改密码的前端验证

用户登录后修改密码&#xff0c;密码需要一定的验证规则。旧密码后端验证是否正确&#xff1b;前端验证新密码的规范性&#xff0c;新密码规范为&#xff1a;6-16位&#xff0c;至少含数字/字母/特殊字符中的两种&#xff1b;确认密码只需要验证与新密码是否一致&#xff1b; 弹…

数据结构——二叉树的遍历【前序、中序、后序】

&#x1f49e;&#x1f49e; 前言 hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#x…

java-教师管理系统全部资料-164-(代码+说明)

转载地址: http://www.3q2008.com/soft/search.asp?keyword教师管理系统全部资料 第一章 综 述 2 1.1 背景说明 2 1.2 设计目的 2 1.3 系统目标 3 1.4 设计指导思想 3 1.5 开发技术概论 3 1.5.1 JSP技术 3 1.5.2 JAVA 4 1.5.3 JavaBeans 5 1.5.4 Servlet 5 1.5.5 Tomcat应用服…

纯前端Web网页内嵌AutoCAD,支持在线编辑DWG、dxf等文档。

随着企业信息化的发展&#xff0c;越来越多的企业有网页在线浏览和编辑DWG文档&#xff08;AutoCad生成的文档&#xff09;的需求&#xff0c;但是新版浏览器纷纷取消了对NPAPI插件的支持&#xff0c;导致之前一些可以在线在线浏览和编辑DWG文档纷纷失效&#xff0c;今天推荐一…