暴力枚举算法

《啊哈!算法》学习笔记

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

        例题一:两方框奥数

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

代码如下: 

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.mfbz.cn/a/881939.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

yolov8模型在Xray图像中关键点检测识别中的应用【代码+数据集+python环境+GUI系统】

yolov8模型在X yolov8模型在Xray图像中关键点检测识别中的应用【代码数据集python环境GUI系统】 1.背景意义 X射线是一种波长极短、穿透能力极强的电磁波。当X射线穿透物体时&#xff0c;不同密度和厚度的物质会吸收不同程度的X射线&#xff0c;从而在接收端产生不同强度的信号…

Python办公自动化教程(003):PDF的加密

【1】代码 from PyPDF2 import PdfReader, PdfWriter# 读取PDF文件 pdf_reader PdfReader(./file/Python教程_1.pdf) pdf_writer PdfWriter()# 对第1页进行加密 page pdf_reader.pages[0]pdf_writer.add_page(page) # 设置密码 pdf_writer.encrypt(3535)with open(./file/P…

Google 扩展 Chrome 安全和隐私功能

过去一周&#xff0c;谷歌一直在推出新特性和功能&#xff0c;旨在让用户在 Chrome 上的桌面体验更加安全&#xff0c;最新的举措是扩展在多个设备上保存密钥的功能。 到目前为止&#xff0c;Chrome 网络用户只能将密钥保存到 Android 上的 Google 密码管理器&#xff0c;然后…

240912-设置WSL中的Ollama可在局域网访问

A. 最终效果 B. 设置Ollama&#xff08;前提&#xff09; sudo vim /etc/systemd/system/ollama.service[Unit] DescriptionOllama Service Afternetwork-online.target[Service] ExecStart/usr/bin/ollama serve Userollama Groupollama Restartalways RestartSec3 Environme…

基于SpringBoot+Vue的时尚美妆电商网站系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 精品专栏&#xff1a;Java精选实战项目源码、Python精…

STM32 单片机最小系统全解析

STM32 单片机最小系统全解析 本文详细介绍了 STM32 单片机最小系统&#xff0c;包括其各个组成部分及设计要点与注意事项。STM32 最小系统在嵌入式开发中至关重要&#xff0c;由电源、时钟、复位、调试接口和启动电路等组成。 在电源电路方面&#xff0c;采用 3.3V 直流电源供…

(已解决)vscode如何传入argparse参数来调试/运行python程序

文章目录 前言调试传入参数运行传入参数延申 前言 以前&#xff0c;我都是用Pycharm专业版的&#xff0c;由于其好像在外网的时候&#xff0c;不能够通过VPN来连接内网服务器&#xff0c;我就改用了vscode。改用了之后&#xff0c;遇到一个问题&#xff0c;调试或者运行python…

解密.bixi、.baxia勒索病毒:如何安全恢复被加密数据

导言 在数字化时代&#xff0c;数据安全已成为个人和企业面临的重大挑战之一。随着网络攻击手段的不断演进&#xff0c;勒索病毒的出现尤为引人关注。其中&#xff0c;.bixi、.baxia勒索病毒是一种新型的恶意软件&#xff0c;它通过加密用户的重要文件&#xff0c;迫使受害者支…

redis基本数据结构-sorted set

1. sorted set的简单介绍 参考链接&#xff1a;https://mp.weixin.qq.com/s/srkd73bS2n3mjIADLVg72A Redis的Sorted Set&#xff08;有序集合&#xff09;是一种数据结构&#xff0c;它是一个不重复的字符串集合&#xff0c;每个元素都有一个对应的分数&#xff08;score&…

科研入门学习

学习视频链接 为什么要读论文 读哪些论文 论文的分类 论文质量 如何找论文 根据领域大牛的名字进行搜索查看高水平论文引用的论文&#xff0c;高水平论文引用的论文很大程度也是高水平的论文 如何整理论文 如何读论文 读论文的困境 不同人群阅读差异 读论文的方式 论文的结构…

Day.js时间插件的安装引用与常用方法大全

&#x1f680; 个人简介&#xff1a;某大型国企资深软件研发工程师&#xff0c;信息系统项目管理师、CSDN优质创作者、阿里云专家博主&#xff0c;华为云云享专家&#xff0c;分享前端后端相关技术与工作常见问题~ &#x1f49f; 作 者&#xff1a;码喽的自我修养&#x1f9…

BLE 设备丢包理解

前言 个人邮箱&#xff1a;zhangyixu02gmail.com在学习 BLE 过程中&#xff0c;总能听到 “丢包” 一词&#xff0c;但是我查阅资料又发现&#xff0c;有大佬说&#xff0c;ATT所有命令都是“必达”的&#xff0c;不存在所谓的“丢包”。而且我发现&#xff0c;在宣传 BLE 产品…

SpringBoot 整合 Caffeine 实现本地缓存

目录 1、Caffeine 简介1.1、Caffeine 简介1.2、对比 Guava cache 的性能主要优化项1.3、常见的缓存淘汰算法1.4、SpringBoot 集成 Caffeine 两种方式 2、SpringBoot 集成 Caffeine 方式一2.1、缓存加载策略2.1.1、手动加载2.1.2、自动加载【Loading Cache】2.1.3、异步加载【As…

Jboss 低版本JMX Console未授权

漏洞描述 此漏洞主要是由于JBoss中/jmx-console/HtmlAdaptor路径对外开放&#xff0c;并且没有任何身份验证机制&#xff0c;导致攻击者可以进⼊到 jmx控制台&#xff0c;并在其中执⾏任何功能 影响范围 Jboss4.x以下 环境搭建 cd vulhub-master/jboss/CVE-2017-7504 doc…

Java笔试面试题AI答之单元测试JUnit(7)

文章目录 37. 请列举一些JUnit扩展 &#xff1f;1. 参数化测试2. 条件测试执行3. 临时目录4. 时间测试5. 重复测试6. 前置/后置条件7. Mockito8. Spring Test9. JUnit Vintage10. Testcontainers11. 自定义注解和扩展12. 测试监听器&#xff08;TestListener 和 RunListener&am…

WIFI路由器的套杆天线简谈

❝本次推文简单介绍下WIFI路由器的套杆天线。 路由器天线 路由器在这个万物互联的时代&#xff0c;想必大家对其都不陌生。随着科技的发展&#xff0c;常用的路由器上的天线也越来越多&#xff0c;那么问题来了&#xff1a;天线越多&#xff0c;信号越好吗&#xff1f;路由器…

智谱清影 - CogVideoX-2b-部署与使用

&#x1f351;个人主页&#xff1a;Jupiter. &#x1f680; 所属专栏&#xff1a;Linux从入门到进阶 欢迎大家点赞收藏评论&#x1f60a; 目录 体验地址&#xff1a;[丹摩DAMODEL官网](https://www.damodel.com/console/overview) CogVideoX 简介本篇将详细介绍使用丹摩服务器部…

Codeforces Round 974 (Div. 3)

比赛地址 : Dashboard - Codeforces Round 974 (Div. 3) - Codeforceshttps://codeforces.com/contest/2014 A 模拟 #include<bits/stdc.h> #define IOS ios::sync_with_stdio(0);cin.tie(0);cout.tie(0); using namespace std;#define endl \n typedef long long …

Qt 模型视图(一):概述

文章目录 Qt 模型视图(一):概述1、模型/视图结构基本原理2、模型3、视图4、代理5、简单实例 Qt 模型视图(一):概述 ​ 模型/视图结构是一种将数据存储和界面展示分离的编程方法。模型存储数据&#xff0c;视图组件显示模型中的数据&#xff0c;在视图组件里修改的数据会被自动…

MySQL练手题--体育馆的人流量(困难)

一、准备工作 Create table If Not Exists Stadium (id int, visit_date DATE NULL, people int); Truncate table Stadium; insert into Stadium (id, visit_date, people) values (1, 2017-01-01, 10); insert into Stadium (id, visit_date, people) values (2, 2017-01-02…