【ACM】—蓝桥杯大一暑期集训Day5

🚀欢迎来到本文🚀
🍉个人简介:陈童学哦,目前正在学习C/C++、Java、算法等方向,一个正在慢慢前行的普通人。
🏀系列专栏:陈童学的日记
💡其他专栏:C++STL,感兴趣小伙伴可以了解一下哦
🎁希望各位→点赞👍 + 收藏⭐️ + 留言📝 ​
⛱️万物随心起,心动则万物动🤺

在这里插入图片描述

Day5集训

  • 前言
  • A - 关于gcd
    • 解题思路
    • 示例代码
  • B - gcd区间
    • 解题思路
    • 示例代码
  • C - Cipher Shifer
    • 解题思路
    • 示例代码
  • D - 质数筛
    • 解题思路
    • 示例代码
  • E - 完全平方数
    • 解题思路
    • 示例代码
  • F - Vika and Her Friends
    • 解题思路
    • 示例代码
  • 总结

前言

因参加了我校的ACM暑期集训为之后的xcpc等赛事做准备,所以就有了此文哈哈。本文主要复盘做题的过程以及一些感悟,便于复习巩固。辣么现在废话也不多说啦,直接往下看吧哈哈。

A - 关于gcd

来源:洛谷P4549 【模板】裴蜀定理
算法标签:数学、最大公约数、gcd不定方程
在这里插入图片描述

解题思路

这题要用到裴蜀定理(或称贝祖定理),那么这个勾八定理是干啥的,怎么用呢?它其实就是二元一次方程ax+by=c存在整数解时c应为a、b的最小公约数。但是这里要注意将负数变为正后再求。

示例代码

#include<bits/stdc++.h>
using namespace std;
int n,a,res;
int gcd(int x,int y)
{return !y?x:gcd(y,x%y); 辗转相除法求最大公约数
}
int main()
{cin>>n;for(int i=1;i<=n;i++){cin>>a;a=a>0?a:-a;res=gcd(res,a);}cout<<res;
}

B - gcd区间

来源:洛谷P1890 gcd区间
算法标签:数学
在这里插入图片描述

解题思路

这题就是求所给区间的最大公约数,我看有大佬用线段树做的(但是我不会哈哈),我用动规思想做的

示例代码

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll a,b,k[1005][1005],d,p;
int main()
{cin>>a>>b;for(int i=1;i<=a;i++)cin>>k[i][i];for(int i=a-1;i>=1;i--)for(int j=i+1;j<=a;j++)k[i][j]=__gcd(k[i][i],k[i+1][j]);for(int i=1;i<=b;i++){cin>>d>>p;cout<<k[d][p]<<endl;}		}

C - Cipher Shifer

来源:CodeforcesA. Cipher Shifer
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

解题思路

遍历字符串并更新字符即可

示例代码

#include<bits/stdc++.h>
using namespace std;
int main()
{int t,n;cin>>t;for(int i=0;i<t;i++){cin>>n;char c[110],b;cin>>c;b=c[0];for(int j=1;j<n;j++){if(b==c[j]){cout<<c[j];j++;b=c[j];}}if(i!=t-1)cout<<endl;}
}

D - 质数筛

来源:洛谷P5736 【深基7.例2】质数筛
在这里插入图片描述

解题思路

这题其实写个判断素数的函数就OK了,对啦,质数就是素数哦!

示例代码

#include<bits/stdc++.h>
using namespace std;
int n,m;
bool judge(int x)
{if(x<=1)return false;for(int i=2;i<=sqrt(x);i++){if(x%i==0)return false;}return true;
}
int main()
{cin>>n;for(int i=1;i<=n;i++){cin>>m;if(judge(m))cout<<m<<" ";}
}

E - 完全平方数

来源:洛谷P8754 [蓝桥杯 2021 省 AB2] 完全平方数
算法标签:数论、素数判断、质数、筛法
在这里插入图片描述

解题思路

完全平方数想必大家都听过撒,而完全平方数有一个性质:完全平方数的质因子的指数一定为偶数。
什么意思呢?如:36=2^2 x 3^2= 6^2

示例代码

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n,x=1;
int main()
{cin>>n;for(ll i=2;i*i<=n;i++){int cnt=0;while(n%i==0)cnt++,n/=i;if(cnt%2==1)x*=i;}x*=n;cout<<x;
}

F - Vika and Her Friends

来源:CodeforcesA. Vika and Her Friends
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

解题思路

如果距离为奇数,那么就抓不住Vika,只有为偶数时才能抓住(我也不知道怎么说啦)

示例代码

#include<bits/stdc++.h>
using namespace std;
int t;
int n,m,k;
int x,y,a,b,flag;
int main()
{	cin>>t;while(t--){flag=0;cin>>n>>m>>k>>x>>y;for(int i=0;i<k;i++){cin>>a>>b;if((abs(x-a)+abs(y-b))%2==0)flag=1;}if(flag)printf("NO\n");elseprintf("YES\n");}
}

总结

ADay5的题主要是数论的题。
算法:数论、最大公约数
感悟:想要学好算法,数学还是不能落下的呀(手动哭脸)
总结:数论的题偏数学里的解题思路

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

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

相关文章

Qt6 Qt Quick UI原型学习QML第五篇

文章目录 效果QML语法父文件 MyQML.qmlQML语法子文件 TLineEditV1.qmlQML语法子文件 TTextEdit.qml 效果 QML语法父文件 MyQML.qml import QtQuick 2.12 import QtQuick.Window 2.12 import QtQuick.Controls 2.12Window {id: windowvisible: truewidth: 600height: 600title:…

Linux系统进程概念详解

这里写目录标题 冯诺依曼体系结构操作系统(Operator System)1.概念2.目的3.管理4.系统调用和库函数概念 进程1.概念2.描述进程-PCB3.查看进程4.通过系统调用获取进程标示符5.通过系统调用创建进程-fork 进程状态1.Linux内核源代码2.进程状态查看 进程优先级1.基本概念2.查看系统…

投个 3D 冰壶,上班玩一玩

本篇文章将介绍如何使用物理引擎和图扑 3D 可视化技术来呈现冰壶运动的模拟。 Oimo.js 物理引擎 Oimo.js 是一个轻量级的物理引擎&#xff0c;它使用 JavaScript 语言编写&#xff0c;并且基于 OimoPhysics 引擎进行了改进和优化。Oimo.js 核心库只有 150K &#xff0c;专门用…

交易流水指标统计——pandas

1、根据交易流水&#xff0c;计算每个交易交易对象的如下指标&#xff0c; 总收入笔数、总收入月数、最大月收入笔数、最大月收入笔数所在日期&#xff08;年月日格式&#xff09; import pandas as pd path r"C:\Users\xxx\Desktop\科技数据.xlsx"df pd.read_exc…

5G的发展过程

目录 1.什么是5G 2.5G与4G的区别 3.5G的应用领域 4.5G给人类带来的福利 5.5G未来的发展趋势 1.什么是5G 5G技术是第五代移动通信技术&#xff0c;它是对之前的2G、3G和4G技术的升级和革新。5G技术具有更高的数据传输速度、更低的延迟和更大的网络容量&#xff0c;为人们提供…

Java-API简析_java.net.InetSocketAddress类(基于 Latest JDK)(浅析源码)

【版权声明】未经博主同意&#xff0c;谢绝转载&#xff01;&#xff08;请尊重原创&#xff0c;博主保留追究权&#xff09; https://blog.csdn.net/m0_69908381/article/details/131870760 出自【进步*于辰的博客】 因为我发现目前&#xff0c;我对Java-API的学习意识比较薄弱…

GAMES104复习总结,课堂提炼(一)

主要是给自己看的&#xff0c;Games104课程很全面&#xff0c;王希老师学识广播&#xff0c;课程组也很认真努力。但是在文字版里面有大量的示例&#xff0c;比如可能会为了引入话题讲个故事等等。。。对于上课来说引人入胜&#xff0c;对于要找工作的我来说&#xff0c;每次看…

办公软件ppt的制作

毕业找工作太难了&#xff0c;赶紧多学点什么东西吧&#xff0c;今天开始办公软件ppt的制作学习。 本文以WPS作为默认办公软件&#xff0c;问为什么不是PowerPoint&#xff0c;问就是没钱买不起&#xff0c;绝对不是不会破解的原因。 一.认识软件 在快捷工具栏中顾名思义就是一…

微服务基础理论

微服务简介 微服务Microservices之父&#xff0c;马丁.福勒&#xff0c;对微服务大概的概述如下&#xff1a; 就目前而言&#xff0c;对于微服务业界并没有一个统一的、标准的定义&#xff08;While there is no precise definition of this architectural style ) 。但通在其…

Express 框架的基本操作

目录 1、应用生成器 2、基本路由 2.1、在跟路由下配置 GET请求&#xff0c;返回对应相应内容。 2.2、在跟路由下配置 POST请求&#xff0c;返回对应相应内容。 2.3、在跟路由下配置 PUT请求&#xff0c;返回对应相应内容。 2.4、在根路由下配置DELETE请求&#xff0c;返回对…

音视频开发-ffmpeg介绍-系列一

目录 一.简介 FFmpeg框架的基本组成包含: 二. FFmpeg框架梳理音视频的流程​编辑 基本概念&#xff1a; 三.ffmpeg、ffplay、ffprobe区别 4.1 ffmpeg是用于转码的应用程序 4.2 fffplay是用于播放的应用程序 4.3 ffprobe是用于查看文件格式的应用程序 4.4 ffmpeg是用于转…

华为鲲鹏920 aarch64 版本 Ambari HDP 下载地址

声明&#xff1a;为有效缓解各位同行兄弟们的痛&#xff0c;特推出此文 本文能够适配兼容 华为鲲鹏920 aarch64 版本&#xff0c;仅限 CentOS7、openEuler20.03-LTS 操作系统 以下是详细下载地址 1、CentOS7 aarch64版本 CentOS7 aarch64 https://mirrors.huaweicloud.com/…

Langchain 的 Conversation summary memory

Langchain 的 Conversation summary memory 现在让我们看一下使用稍微复杂的内存类型 - ConversationSummaryMemory 。这种类型的记忆会随着时间的推移创建对话的摘要。这对于随着时间的推移压缩对话中的信息非常有用。对话摘要内存对发生的对话进行总结&#xff0c;并将当前摘…

91、RabbitMQ事务消息

RabbitMQ事务消息 通过对信道的设置实现 channel.txSelect(); 通知服务器开启事务模式;服务端会返回Tx.Select-ok channel.basicPublish; 发送消息&#xff0c;可以是多条&#xff0c;可以是消费消息提交ack channel.txCommit() 提交事务 channel.txRollback() 回滚事务 …

《零基础入门学习Python》第054讲:论一只爬虫的自我修养2:实战

0. 请写下这一节课你学习到的内容&#xff1a;格式不限&#xff0c;回忆并复述是加强记忆的好方式&#xff01; 今天我们决定在实战中来进行学习&#xff0c;会举两个例子&#xff0c;第一个例子是我们会下载一只猫&#xff0c;第二个例子是我们用Python来模拟浏览器通过在线的…

MySQL8.0索引新特性

文章目录 1 支持降序索引2 隐藏索引 1 支持降序索引 举例&#xff1a;分别在MySQL 5.7版本和MySQL 8.0版本中创建数据表ts1&#xff0c;结果如下&#xff1a; CREATE TABLE ts1(a int,b int,index idx_a_b(a,b desc) );在MySQL 5.7版本中查看数据表ts1的结构&#xff0c;从结…

83、讲下Zookeeper watch机制

讲下Zookeeper watch机制 客户端&#xff0c;可以通过在znode上设置watch&#xff0c;实现实时监听znode的变化。 Watch事件是一个一次性的触发器&#xff0c;当被设置了Watch的数据发生了改变的时候&#xff0c;则服务器将这个改变发送给设置了Watch的客户端 父节点的创建&…

45:ECMAScript 6 简介

ECMAScript 6 简介 [ECMAScript 和 JavaScript 的关系](https://es6.ruanyifeng.com/#docs/intro#ECMAScript 和 JavaScript 的关系)[ES6 与 ECMAScript 2015 的关系](https://es6.ruanyifeng.com/#docs/intro#ES6 与 ECMAScript 2015 的关系)语法提案的批准流程[ECMAScript 的…

选择前端框架重要依据是什么?

状态更改检测&#xff0c;也就是检测应用程序对状态值的改变&#xff0c;这样才会相应地更新 UI。 &#xff08;#MVC模式中模型Model的改变会更新View界面UI&#xff0c;这点类似后端的ORM&#xff0c;对象状态更改通过ORM框架自动变更相应数据表值&#xff09; 变更检测是前…

IntelliJ IDEA2023中利用maven-archetype-quickstart模板创建项目无src文件夹及maven插件下载过慢问题的解决

目录 介绍问题之解决问题2的解决问题1的解决 介绍 昨天下载并安装了IntelliJ IDEA 2023的最新版&#xff08;以下简称为IDEA 2023&#xff09;&#xff0c;学习利用该IDE编写Java项目及将其与maven结合构建项目。我所安装的maven是去年暑假安装的&#xff0c;版本为Apache Mav…