第十三届蓝桥杯省赛大学B组编程题(c++)

2024-04-12 12:52

本文主要是介绍第十三届蓝桥杯省赛大学B组编程题(c++),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

D.刷题统计

二分(AC):

注意:二分时右边界 right 的确定

#include<iostream>
using namespace std;
long long a,b,n;
bool check(long long x){long long t=x/7;x%=7;long long temp=0;if(x<=5) temp=x*a;else temp=5*a+(x-5)*b;long long cnt=t*(5*a+2*b)+temp;return cnt>=n;
}
int main(){cin>>a>>b>>n;long long left=0,right=n/min(a,b)+1;while(left<right){long long mid=(left+right)/2;if(check(mid)) right=mid; else left=mid+1;}cout<<left<<endl;return 0;
}

E.修剪灌木

数学思维(AC):

#include<iostream>
using namespace std;
int n;
int main(){cin>>n;for(int i=1;i<=n;i++){int left=2*(i-1);int right=2*(n-i);cout<<max(left,right)<<endl;}return 0;
}

F.X 进制减法

暴力+模拟(AC):

十年OI一场空,不开浪浪见祖宗

#include<iostream>
using namespace std;
typedef long long ll;
const int N=1e5+5;
const ll mod=1e9+7;
ll n,ma,mb,ans1,ans2,a[N],b[N],x[N],v[N];
int main(){ios::sync_with_stdio(false),cin.tie(0);cin>>n>>ma;for(int i=ma-1;i>=0;i--) cin>>a[i];cin>>mb;for(int i=mb-1;i>=0;i--) cin>>b[i];for(int i=max(ma-1,mb-1);i>=0;i--) x[i]=max((long long)2,max(a[i]+1,b[i]+1));for(int i=0;i<=max(ma,mb)-1;i++){if(i==0) v[i]=1;else{v[i]=v[i-1]*x[i-1];v[i]%=mod;}}for(int i=ma-1;i>=0;i--) ans1+=v[i]*a[i],ans1%=mod;for(int i=mb-1;i>=0;i--) ans2+=v[i]*b[i],ans2%=mod;cout<<(ans1-ans2+mod)%mod<<endl;return 0;
}

G.统计子矩阵

二维前缀和+暴力(70 points):

#include<iostream>
using namespace std;
const int N=505;
int n,m,k,a[N][N];
long long ans;
int main(){cin>>n>>m>>k;for(int i=1;i<=n;i++) {for(int j=1;j<=m;j++) {cin>>a[i][j];a[i][j]+=a[i-1][j]+a[i][j-1]-a[i-1][j-1];}}for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){for(int x=1;x<=i;x++){for(int y=1;y<=j;y++){if(k>=(a[i][j]+a[x-1][y-1]-a[x-1][j]-a[i][y-1])){ans++;}}}}}cout<<ans<<endl;return 0;
}

优化(AC):

#include<iostream>
using namespace std;
const int N=505;
int n,m,k,a[N][N];
long long ans;
int main(){cin>>n>>m>>k;for(int i=1;i<=n;i++) {for(int j=1;j<=m;j++) {cin>>a[i][j];a[i][j]+=a[i-1][j]+a[i][j-1]-a[i-1][j-1];}}for(int i=1;i<=n;i++){for(int j=i;j<=n;j++){for(int l=1,r=1;r<=m;r++){while(l<=r&&k<(a[j][r]+a[i-1][l-1]-a[j][l-1]-a[i-1][r])){l++;}ans+=r-l+1;}}}cout<<ans<<endl;return 0;
}

这题暴力70足以...... 

H.积木画

递推与递归(AC):

#include<iostream>
using namespace std;
const long long mod=1e9+7;
const int N=1e7+5;
int n,f[N];
int main(){cin>>n;f[1]=1,f[2]=2,f[3]=5;if(n>=4){for(int i=4;i<=n;i++){f[i]=2*f[i-1]%mod+f[i-3]%mod;f[i]%=mod;}}cout<<f[n]<<endl;return 0;
}

思路和洛谷题单算法1-4递推与递归 P1990 覆盖墙壁 一模一样......

I.李白打酒加强版

动态规划+记忆化搜索(AC):

#include<iostream>
#include<cstring>
using namespace std;
const int N=105;
const int mod=1e9+7;
int n,m,dp[N][N][N];//当前酒量,剩余遇见店的次数,剩余遇见花的次数
int dfs(int x,int y,int z) {//出现负数不合法if(x<0||y<0||z<0) return 0;//当前酒量不可能大于剩余遇见花的次数"if(x>z) return 0;//最后一次必须遇见花并且酒量只剩1if(z==1) return y==0&&x==1;//记忆化if(dp[x][y][z]!=-1) return dp[x][y][z];//逢店加倍,遇花减一dp[x][y][z]=(dfs(x*2,y-1,z)+dfs(x-1,y,z-1))%mod;return dp[x][y][z];
}
int main(){memset(dp,-1,sizeof(dp));cin>>n>>m;cout<<dfs(2,n,m)<<endl;return 0;
}

J.砍竹子

unorder_set特点:无序不重复的集合
//头文件:
#include<unordered_set>
//常用函数:
unorder_set.empty();  //判断容器是否为空,空为true,反之为false
unorder_set.size();   //返回容器大小
unorder_set.begin();  //返回迭代器开始
unorder_set.end();    //返回迭代器结束
unorder_set.find(x);  //返回x在迭代器的位置
unorder_set.count(x); //返回x在容器的个数
unorder_set.insert(x);//将x插入到容器中
unorder_set.erase(x); //删除x,成功返回1,反之返回0
unorder_set.clear();  //清空容器

解释样例:

#include<iostream>
#include<unordered_set>
#include<cmath>
typedef long long ll;
using namespace std;
ll ans;            //累计不同的数的个数
unordered_set<ll>s;//保存上次出现过的数
int main() {int n;cin>>n;for(int i=1;i<=n;i++) {ll temp;cin>>temp;unordered_set<ll>cur;  //每次读取一个数时,用来记录当前数的所有中间结果while(temp!=1) {cur.insert(temp);  //将当前数加入当前集合if (s.find(temp)==s.end()) ans++;//如果当前数不在之前的集合内,ans自增temp = sqrtl(temp/2+1);          //计算下一个数}s=cur; //更新保存所有出现过的数的集合}cout<<ans<<endl;return 0;
}

这题真难想...... 

这篇关于第十三届蓝桥杯省赛大学B组编程题(c++)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/897189

相关文章

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

C++ 各种map特点对比分析

《C++各种map特点对比分析》文章比较了C++中不同类型的map(如std::map,std::unordered_map,std::multimap,std::unordered_multima... 目录特点比较C++ 示例代码 ​​​​​​代码解释特点比较1. std::map底层实现:基于红黑

C++中函数模板与类模板的简单使用及区别介绍

《C++中函数模板与类模板的简单使用及区别介绍》这篇文章介绍了C++中的模板机制,包括函数模板和类模板的概念、语法和实际应用,函数模板通过类型参数实现泛型操作,而类模板允许创建可处理多种数据类型的类,... 目录一、函数模板定义语法真实示例二、类模板三、关键区别四、注意事项 ‌在C++中,模板是实现泛型编程