当前位置: 首页 > news >正文

备战蓝桥杯---搜索(进阶4)

话不多说,直接看题:

下面是分析:

(a+b)%c=(a%c+b%c)%c;

(a*b)%c=(a%c*b%c)%c;

因此,如果两个长度不一样的值%m为相同值,那就舍弃长的(因为再加1位只不过是原来值*10+那位值,因此他们得出的%m还是同一值)。

因此,我们每次只要BFS最多m-1个值,复杂度为O(k*m*n),其中N为数的位数。

下面是AC代码:

#include<bits/stdc++.h>
using namespace std;
int k,m,vis[10010];
struct node{string s;int yu;
};
queue<node> q;
void bfs(string ss){for(int i=1;i<=k-1;i++){if(vis[i%m]==0){vis[i%m]=1;q.push({to_string(i),i%m});}}while(!q.empty()){node ck=q.front();q.pop();if(ck.yu==0){cout<<ck.s;return;}for(int i=0;i<=k-1;i++){if(vis[(ck.yu*10+i)%m]==1) continue;q.push({ck.s+to_string(i),(ck.yu*10+i)%m});vis[(ck.yu*10+i)%m]=1;}}
}
int main(){cin>>k>>m;bfs("0");
}

接题:

相当于我们要从边界进去一次,并出来一次。

考虑到有a*b个位置可以进,我们可以表示从左上端点开始,可以在边界上动,到了相应的位置再进去即可。

下面是AC代码:

#include<bits/stdc++.h>
using namespace std;
int a,b,w[10][10],cnt,c[20],kk;
int dir[4][2]={{1,0},{0,1},{-1,0},{0,-1}};
void dfs(int x,int y,int k){if(k==2&&(x==0||x==a||y==0||y==b)){cnt++;return;}for(int i=0;i<4;i++){int xx=x+dir[i][0];int yy=y+dir[i][1];if(xx<0||yy<0||xx>a||yy>b) continue;if(w[xx][yy]==1) continue;w[xx][yy]=1;int k1=k;if(xx!=0&&xx!=a&&yy!=0&&yy!=b&&k==1) k1=2;dfs(xx,yy,k1);w[xx][yy]=0;}return;
}
int main(){cin>>a>>b;if(a==1){cout<<b-1;return 0;}w[0][0]=1;w[1][0]=1;dfs(1,0,1);cout<<cnt;
}

接题(很有意思):

我们可以得到:每次切割都应该为x/n,y/n的整数倍(否则无法切成相等的,可以画图更直观一点)

然后,切的刀数按照倍数分即可。我们先要选出最大值的最小值,于是我们for切刀,递归求出每一种情况的最大值的最小值(注意,每一个被分的两部分求max,因为他们两个共同组成这一种情况)

下面是AC代码:

#include<bits/stdc++.h>
using namespace std;
double x,y;
int n1;
double dfs(double x,double y,int n){if(n==1){return max(x,y)/min(x,y);}double ans=10001;double xx=x/n;double yy=y/n;for(int i=1;i<=n-1;i++){double aa=max(dfs(xx*i,y,i),dfs(x-xx*i,y,n-i));double bb=max(dfs(x,yy*i,i),dfs(x,y-yy*i,n-i));ans=min(ans,aa);ans=min(ans,bb);}return ans;
}
int main(){cin>>x>>y>>n1;printf("%.6lf",dfs(x,y,n1));
}

http://www.lryc.cn/news/296428.html

相关文章:

  • 51单片机基础(C语言):定时器时钟
  • 单片机无线发射的原理剖析
  • Redis的过期键的删除策略
  • 放假--寒假自学版 day1(补2.5)
  • LLM(5) | Encoder 和 Decoder 架构
  • CV | Medical-SAM-Adapter论文详解及项目实现
  • C++初阶:容器(Containers)vector常用接口详解
  • flink写入es的参数解析
  • 逆向工程:揭开科技神秘面纱的艺术
  • 决策树的相关知识点
  • 【数据结构】单向链表实现 超详细
  • Opencc4j 开源中文繁简体使用介绍
  • vue 下载二进制文件
  • 数据结构之堆排序
  • 鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之ScrollBar组件
  • 读论文:DiffBIR: Towards Blind Image Restoration with Generative Diffusion Prior
  • 基于微信小程序的新生报到系统的研究与实现,附源码
  • 分享一下 uniapp 打包安卓apk
  • DevOps落地笔记-21|业务价值:软件发布的最终目的
  • 【动态规划】【前缀和】【数学】2338. 统计理想数组的数目
  • 【已解决】onnx转换为rknn置信度大于1,图像出现乱框问题解决
  • 多路服务器技术如何处理大量并发请求?
  • SpringBoot - 不加 @EnableCaching 标签也一样可以在 Redis 中存储缓存?
  • Linux------命令行参数
  • LLM少样本示例的上下文学习在Text-to-SQL任务中的探索
  • 双非本科准备秋招(19.2)—— 设计模式之保护式暂停
  • 使用SpringMVC实现功能
  • spring aop实现接口超时处理组件
  • c++设计模式之装饰器模式
  • WordPress如何实现随机显示一句话经典语录?怎么添加到评论框中?