暴力破解法是指从可能的解集合(空间)中一一列举各情况,用题目给定的检验条件判定哪些是没用的,哪些是有用的。能使命题成立的值,即为问题的解。

基本思路:
(1)确定问题的可能解的范围(可能解的空间)。

(2)逐一列出可能解集合中的元素,验证是否是问题的解。

优化方向:通过加强约束条件,缩小可能解的集合的规模。
按照暴力破解法的思想,我们首先会想到的就是直接所有循环破解。

解法一:
1.抽象出数学模型,这里指的就是方程组

设公鸡为x,母鸡为y,小鸡为z,

鸡: x+y+z=100

钱: 5x+3y+1/3z=100

2.代码

#include<iostream>

using namespace std;

int main()

{   

 int x,y,z;   

 for(x=0;x<=20;x++)//公鸡不会超过20只       

 for(y=0;y<=34;y++)//母鸡不会超过34只           

 for(z=0;z<=100;z++)//小鸡不会超过100只               

 if((x+y+z)==100 && (5*x+3*y+z/3)==100&&z%3==0)//同时要满足z是3的整数

cout<<"cock="<<x<<","<<"hen="<<y<<","<<"chicken="<<z<<endl;    

return 0;

}


解法二:
1.减少一个循环的嵌套,模型不变,进一步优化算法

2.代码

#include<iostream>

using namespace std;

int main(){    int x,y,z;   

 for(x=0;x<=20;x++)//公鸡不会超过20只        

for(y=0;y<=34;y++)//母鸡不会超过34只        

{            z=100-x-y;//根据x,y可求出z            

if(z==(300-15*x-9*y)&&z%3==0)

cout<<"cock="<<x<<","<<"hen="<<y<<","<<"chicken="<<z<<endl;        

}                            

return 0;

}

解法三:1. 继续减少一个循环的嵌套

鸡: x+y+z=100

钱: 15x+9y+z=300

=>>7x+4y=100 ->y ->z

2.代码:

#include<iostream>

using namespace std;

int main()

{    

int x,y,z;    

for(x=0;x<=20;x++)//公鸡不会超过20只    

{        

y=25-1.75*x;//先求y       

 z=100-x-y;//再求z        

if(z==(300-15*x-9*y)&&z%3==0&&y>0&&&z>0)

cout<<"cock="<<x<<","<<"hen="<<y<<","<<"chicken="<<z<<endl;    

}   

 return 0;

}

因为【判断不太严格】,so————————————————————————————偷鸡


                                                                                           代码如下:

#include<iostream>

using namespace std;

int main()

{

   cout<<"cock=0,hen=25,chicken=75"<<endl<<"cock=4,hen=18,chicken=78"<<endl<<"cock=8,hen=11,chicken=81"<<endl<<"cock=12,hen=4,chicken=84";

   return 0;

}




点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论