暴力枚举算法

《啊哈!算法》学习笔记

        本博客的题目仅用暴力枚举,并不一定是最好的解法,主要是了解枚举算法

        例题一:两方框奥数

               在两个方框内填入相同的数字使得等式成立: 

代码如下: 

for(i=1;i<=9;i++)
{if((i*10+3)*6528 == (30+i)*8256)printf("%d",i);
}

        

        例题二:九方框奥数

        将数字1~9分别填入9个方框中,每个数字只能使用一次使等式成立,例如173+286=459,其中286+173=459与173+286=459是同一种组合。

 

#include<stdio.h>int main()
{int a,b,c,d,e,f,g,h,i,total = 0;for(a=1;a<=9;a++)for(b=1;b<=9;b++)for(c=1;c<=9;c++)for(d=1;d<=9;d++)for(e=1;e<=9;e++)for(f=1;f<=9;f++)for(g=1;g<=9;g++)for(h=1;h<=9;h++)for(i=1;i<=9;i++){if (a!=b && a!=c  && a!=d  && a!=e  && a!=f  && a!=g  && a!=h  && a!=i &&  b!=c && b!=d  && b!=e  && b!=f  && b!=g  && b!=h  && b!=i&&  c!=d && c!=e  && c!=f  && c!=g  && c!=h  && c!=i&&  d!=e && d!=f  && d!=g  && d!=h  && d!=i&&  e!=f && e!=g  && e!=h  && e!=i&&  f!=g && f!=h  && f!=i&&  g!=h && g!=i&&  h!=i&& a*100+b*10+c+d*100+e*10+f == g*100+h*10+i){total++;printf("%d%d%d+%d%d%d=%d%d%d\n",a,b,c,d,e,f,g,h,i);}}printf("total=%d",total/2);return 0;}

其中的a,b,c,d,e,f,g,h,i可以用一个数组代替 ,然后用标记的方法判断互不相等。代码如下:

#include<stdio.h>int main()
{int a[9]={0};int book[9]={0};int sum = 0,total=0;for(a[0]=1;a[0]<=9;a[0]++)for(a[1]=1;a[1]<=9;a[1]++)for(a[2]=1;a[2]<=9;a[2]++)for(a[3]=1;a[3]<9;a[3]++)for(a[4]=1;a[4]<=9;a[4]++)for(a[5]=1;a[5]<=9;a[5]++)for(a[6]=1;a[6]<=9;a[6]++)for(a[7]=1;a[7]<=9;a[7]++)for(a[8]=1;a[8]<=9;a[8]++){for (int i = 0; i < 9; i++){book[i]=0;}for (int i = 0; i < 9; i++){book[a[i]-1]=1;}sum = 0;for (int i = 0; i < 9; i++){sum+=book[i];}if (sum==9 && a[0]*100+a[1]*10+a[2]+a[3]*100+a[4]*10+a[5] == a[6]*100+a[7]*10+a[8]){total++;printf("%d%d%d+%d%d%d=%d%d%d\n",a[0],a[1],a[2],a[3],a[4],a[5],a[6],a[7],a[8]);}   }printf("total=%d",total/2);return 0;
}

如果sum等于9,就代表1~9每个数字只有一个。

例题三:炸弹人

        现在有一个特殊关卡如图。你只有一枚炸弹,但是这枚砸蛋威力超强(杀伤距离超长,可消灭杀伤范围内所有的敌人)。请问在哪里放置炸弹才可以消灭最多的敌人呢?

        我们先将这个地图模型化。墙用#表示。这里有两种墙,一种是可以被炸掉的但是由于现在只有一种炸弹,所以用#表示,炸弹是不能穿墙的。敌人用G表示,空地用 . 表示,当然炸弹只能放地上。

#############
#GG.GGG#GGG.#
###.#G#G#G#G#
#.......#..G#
#G#.###.#G#G#
#GG.GGG.#.GG#
#G#.#G#.#.###
##G...G.....#
#G#.#G###.#G#
#...G#GGG.GG#
#G#.#G#G#.#G#
#GG.GGG#G.GG#
#############  

我们需要统计上下左右四个方向消灭的敌人数。代码如下:

#include<stdio.h>int main()
{int x=0,y=0;char a[30][30]={'\0'};int i=0,j=0,m=0,n=0,sum=0,max=0,p=0,q=0;scanf("%d %d",&x,&y);getchar(); //读入换行符for ( i = 0; i < x; i++){for ( j = 0; j < y; j++){scanf("%c",&a[i][j]);  //读入地图// printf("yes!");}getchar(); //读入换行符}// ******************************测试读入数据for (int i = 0; i < x; i++){for (int j = 0; j < y; j++){printf("%c",a[i][j]);}printf("\n");}// ********************************for ( i = 0; i < x; i++){for ( j = 0; j < y; j++)  {if (a[i][j] == '.')   //枚举每块空地      {sum=0;// 该点上方敌人n=i,m=j;while (a[n][m]!='#')  //不为墙则继续搜索敌人{if (a[n][m] == 'G')  //为敌人则消灭{sum++;        //该空地消灭敌人总数加1}n--;printf("%d %d\n",n,m);}// 该点下方敌人n=i,m=j;while (a[n][m]!='#'){if (a[n][m] == 'G'){sum++;}n++;printf("%d %d\n",n,m);}// 该点左方敌人n=i,m=j;while (a[n][m]!='#'){if (a[n][m] == 'G'){sum++;}m--;printf("%d %d\n",n,m);}// 该点右方敌人n=i,m=j;while (a[n][m]!='#'){if (a[n][m] == 'G'){sum++;}m++;printf("%d %d\n",n,m);}if (sum>max)  //统计所有点中消灭敌人最大总数{max=sum;p=i;q=j;} }}}printf("(%d,%d)  %d",p,q,max);return 0; 
}

例题四:火柴棍等式 

         现在小哼有n根火柴,希望拼出形如A+B=C的等式。等式中的A、B、C均是用火柴棍拼出来的整数(若该数为非零,则最高位不能是0)。数字0~9的拼法如下图:

        例如现在小哼手上有14根火柴棍,则可以拼出两个不同的等式 0+1=1和1+0=1。

        再例如小哼有18根火柴棍,可以拼出9个等式:0+4=4、0+11=11、1+10=11、2+2=4、2+7=9、10+1=11和11+0=11。

        注意:

  • 加号和等号各自需要两根火柴。
  • 如果A!=B,则A+B=C与B+A=C是两个等式(A、B不能全为0)
  • 所有火柴棍都必须用上。
  • 规定时间为1s。

本题较为复杂,约束条件更多的需要我们自己去想,范围越小时间复杂度就越低。

        大题思路就是枚举A、B、C从零到各自的最大值,在满足约束条件的前提下形成等式。

我们先找出n个火柴拼出的A、B、C各自的最大值,假设火柴有24根,去掉+和=还有20个,可以组成10个1,A和B的值肯定小于等于C。

        我们假设B为0,还剩14根,A和C平分最大值为7根火柴;确定一个大致范围为小于1111(当然更精细也行)。那么就可以得到A、B、C的范围为0~1111。

        我们遍历A、B、C的时间复杂度为O(N^3)=1111^3,那我们可以想一想有没有办法降低一点,我们加上约束条件A+B=C便可直接得到C,将算法复杂度降到O(N^2)=1111^2;

        那么有一个问题,A+B=C(A==B)这种情况的约束条件怎么写呢?其实只需要考虑一种情况,这种情况只有0满足,0由六个火柴棍组成,共6×3+4=22个.并且只用22根火柴才会出现

#include<stdio.h>int num[10]={6,2,5,5,4,5,6,3,7,6}; //存放)0~9每个数字所需的火柴根数
int fun(int x) //返回A,B,C各自需要的火柴数
{int sum = 0;while (x/10!=0)  //两位数及以上的火柴数{sum+=num[x%10];x=x/10;}sum+=num[x]; //个位数火柴数return sum;
}int main()
{int A=0,B=0,C=0;int flag=0,sum=0;scanf("%d",&flag); //火柴总数int n=flag-4; //去掉+和=后的火柴总数for ( A = 0; A <= 1111; A++){for ( B = 0; B <= 1111; B++){C=A+B;if (fun(A)+fun(B)+fun(C)==n)//相加等于火柴数 {printf("%d + %d = %d\n",A,B,C);sum++;}}}if (n==18){sum--;}printf("%d",sum);return 0;
}

例题五:数的全排列

         123的全排列是123、132、213、312。1234的全排列为:1234 1243 1324 1342 1423 1432 2134 2143 2314 2341 2413 2431 3124 3142 3214 3241 3412 3421 4123 4132 4213 4231 4321

        求123的全排列

for(a=1;a<=3;a++)for(b=1;b<=3;b++)for(d=1;d<=3;d++){if(a!=b && a!=c && b!=c)printf("%d%d%d\n",a,b,c);}

        1234就是四层循环,如果123456789就需要9层循环,可以写出来,但复杂,大家可以去了解一下“搜索”算法来做这道题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/146290.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

数据结构---二叉搜索树(二叉排序树)

什么是二叉排序树 二叉搜索树又是二叉排序树&#xff0c;当我们的是一颗空树或者具有以下性质时&#xff1a; 左子树不为空&#xff0c;左子树上的值都小于我们的根节点上的值。右子树不为空时&#xff0c;右子树上的值都大于我们的根节点上的值左右子树都是二叉搜索树&#…

Java异常架构与异常关键字

1. Java异常简介 Java 异常是 Java 提供的一种识别及响应错误的一致性机制。 Java 异常机制可以使程序中异常处理代码和正常业务代码分离&#xff0c;保证程序代码更加优雅&#xff0c;并提高程 序健壮性。在有效使用异常的情况下&#xff0c;异常能清晰的回答 what, where,…

2023北华大学程序设计新生赛部分题解

时光如流水般逝去&#xff0c;我已在校园中奋战大二&#xff01;(≧▽≦) 今天&#xff0c;静静回顾去年的新生赛&#xff0c;心中涌起无尽感慨&#xff0c;仿佛那段青春岁月如烟花般绚烂。✧&#xff61;(≧▽≦)&#xff61;✧ 青春就像一场燃烧的盛宴&#xff0c;激情澎湃&…

《高等代数》线性相关和线性无关(应用)

说明&#xff1a;此文章用于本人复习巩固&#xff0c;如果也能帮到大家那就更加有意义了。 注&#xff1a;1&#xff09;线性相关和线性无关的证明方法中较为常用的方法是利用秩和定义来证明。 2&#xff09;此外&#xff0c;线性相关和线性无关的证明常常也会用到反证法。 3&…

2.5 数据库索引机制

我们往数据表里面保存数据记录越来越多&#xff0c;一旦达到上千万条&#xff0c;那怎么提高检索速度就需要认真考虑了。我们打开手机上的APP都希望能快些加载出内容&#xff0c;这里的因素有很多&#xff0c;但是如何减少数据查找的时间是其中的重要一环。索引机制就是提升数据…

怎么给视频加字幕?6种给视频加字幕最简单的方法,不怕你学不会!

在这个快节奏的时代&#xff0c;越来越多的人会在公共场所观看视频&#xff0c;但为了不影响其它人&#xff0c;大多数人往往会将声音关闭。统计数据显示&#xff0c;高达69%的人在这样的环境中会静音观看视频&#xff0c;而有字幕的情况下&#xff0c;80%的人更倾向于完整观看…

刷题训练之栈

> 作者&#xff1a;დ旧言~ > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 目标&#xff1a;熟练掌握字符串算法。 > 毒鸡汤&#xff1a;学习&#xff0c;学习&#xff0c;再学习 ! 学&#xff0c;然后知不足。 > 专栏选自&#xff1a;刷题…

C++之spring

C之spring string类对象的访问及遍历操作 operator[] 返回pos位置的字符&#xff0c;const string类对象调用 这是一个既可以写也可以读的库函数&#xff0c;const修饰的内容是不可以更改的&#xff0c;所以是读 C类与对象里要想普通对象和const修饰的对象同时重载 第二种访…

2024华为杯研究生数学建模,代码思路和参考文章

F题X射线脉冲星光子到达时间建模&#xff0c; E题高速公路应急车道紧急启用模型&#xff0c; D题大数据驱动的地理综合问題&#xff0c; C题数据驱动下磁性元件的磁芯损耗建模&#xff0c; B题W LAN 组网中网络吞吐量建模&#xff0c; A题风电场有功功率优化分配&#xff…

Python画笔案例-057 绘制蜘蛛网

1、绘制蜘蛛网 通过 python 的turtle 库绘制 蜘蛛网&#xff0c;如下图&#xff1a; 2、实现代码 绘制蜘蛛网&#xff0c;以下为实现代码&#xff1a; """蜘蛛网.py """ import turtledef draw_circle(pos,r):"""pos:圆的中心点…

力扣最热一百题——搜索二维矩阵

目录 题目链接&#xff1a;240. 搜索二维矩阵 II - 力扣&#xff08;LeetCode&#xff09; 题目描述 解法一&#xff1a;暴力不解释 Java写法&#xff1a; 运行时间 C写法&#xff1a; 运行时间 时间复杂度以及空间复杂度 解法二&#xff1a;利用自带的大小关系进行Z型走…

电商ISV 电商SaaS 是什么

Independent Software Vendors的英文缩写&#xff0c;意为“独立软件开发商” 软件即服务(SaaS) 指一种基于云技术的软件交付模式 订阅收费 这些公司叫做ISV软件供应商&#xff0c;通过SaaS服务交付收费 为什么会有电商ISV 从商家角度划分&#xff1a;有独立品牌商家、大商…

叉车限速器外接LED屏,监督厂区安全,让速度慢下来!

叉车限速器外接LED屏&#xff0c;可实时显示当前叉车行驶中的速度&#xff0c;单/双面电子显示屏供用户选择&#xff0c;方便企业人员监控司机当前行驶速度&#xff0c;当速度超过指定值时&#xff0c;叉车速度报警系统发出声光警示&#xff0c;提醒行人、司机&#xff0c;超速…

最新适用:关于夫妻共同债务的裁判规则+司法观点

✦ 重点条文 ✦ 《民法典》第一千零六十四条 夫妻双方共同签名或者夫妻一方事后追认等共同意思表示所负的债务&#xff0c;以及夫妻一方在婚姻关系存续期间以个人名义为家庭日常生活需要所负的债务&#xff0c;属于夫妻共同债务。 夫妻一方在婚姻关系存续期间以个人名义超…

新手入门:小程序架构快速上手

目录 新建项目和配置 项目基本结构 新建小程序页面 修改项目首页 全局配置 窗口 tabBar 页面配置 小程序基本语法 wxml 数据绑定 条件渲染 列表渲染 wxss wxss 对比 css rpx import 全局样式和局部样式 js wxs 数据请求 get和post请求 小程序和跨域 小程…

特征工程与交叉验证在机器学习中的应用

数据入口&#xff1a;学生考试表现影响因素数据集 - Heywhale.com 本数据集提供了关于影响学生考试成绩的多种因素的全面概述。数据集包含了有关学习习惯、出勤率、家长参与、资源获取等方面的信息。 数据说明 字段名说明Hours_Studied每周学习的小时数Attendance出勤率&…

30个GPT提示词天花板,一小时从大纲到终稿

PROMPT 1 中文&#xff1a;构建研究背景与意义&#xff0c;阐述研究问题的紧迫性和重要性。 English: Establish the research background and significance, elucidating the urgency and importance of the research question. 中文&#xff1a;设计研究目的与目标&#xff…

深入解析:HTTP 和 HTTPS 的区别

网络安全问题正变得日益重要&#xff0c;而 HTTP 与 HTTPS 对用户数据的保护十分关键。本文将深入探讨这两种协议的特点、工作原理&#xff0c;以及保证数据安全的 HTTPS 为何变得至关重要。 认识 HTTP 与 HTTPS HTTP 的工作原理 HTTP&#xff0c;全称超文本传输协议&#xf…

go 安装依赖超时

一、配置代理 go env -w GO111MODULEon go env -w GOPROXYhttps://goproxy.io,direct go get github.com/unidoc/unioffice

对象关系映射ORM

目录 ORM【重要】 1、 什么是ORM 2、 实体类 3、 ORM改造登录案例 ORM【重要】 1、 什么是ORM 目前使用JDBC完成了CRUD,但是现在是进行CRUD,增删改方法要设计很多参数,查询的方法需要设计集合才能返回. 在实际开发中,我们需要将零散的数据封装到对象处理. ORM (Object Rela…