解题思路: 深度优先搜索,用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分
2 人评分
C语言程序设计教程(第三版)课后习题11.1 (C语言代码)浏览:655 |
分糖果 (C++代码)浏览:1438 |
2006年春浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:464 |
出圈】指针malloc版浏览:355 |
C语言程序设计教程(第三版)课后习题12.6 (C语言代码)浏览:649 |
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:484 |
神奇的fans (C语言代码)浏览:977 |
C语言训练-排序问题<1> (C语言代码)浏览:355 |
回文数(一) (C语言代码)浏览:1117 |
母牛的故事 (java语言代码)浏览:880 |