原题链接:蓝桥杯算法训练VIP-瓷砖铺放
解题思路: 深度优先搜索,用1和2两种瓷砖去一一试探,当面积小于要求时深搜
注意事项: 当满足条件后记得加return; 这是递归的出口!
参考代码:
#include<iostream>
using namespace std;
int n,count=0;
void dfs(int area){
if(area>n) return; //面积大于要求的 也得返回
if(area==n){
count++; return; //满足条件得返回
}
//开始铺砖 1和2两种砖 一一尝试!
int i;
for(i=1;i<=2;i++){
if(area<n){ //面积达不到要求才深搜
dfs(area+i); //面积的递增
}
}
}
int main(){
cin>>n;
dfs(0); //初始面积为0
cout<<count;
return 0; }0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复