暴力破解法是指从可能的解集合(空间)中一一列举各情况,用题目给定的检验条件判定哪些是没用的,哪些是有用的。能使命题成立的值,即为问题的解。
基本思路:
(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分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复