草庐IT

蓝桥杯刷题冲刺 | 倒计时18天

指针不指南吗 2023-04-09 原文

作者:指针不指南吗
专栏:蓝桥杯倒计时冲刺

🐾马上就要蓝桥杯了,最后的这几天尤为重要,不可懈怠哦🐾

文章目录

今天写 搜索题

0.知识点

  • DFS

    • 设计步骤
    1. 确定该题目的状态(包括边界)
    2. 找到状态转移方式
    3. 找到问题的出口、计数或者某一个状态
    4. 设计搜索
    • 代码模板
    ans  //答案,用全局变量来表示
    
    bool st[N]; //标记状态
        
    bool check(参数)
    {
    	if(满足条件)
            return 1;
        return 0;
    }
    
    void dfs(int step)
    {
    	if(判断边界)
        {
    		不在边界内,即回溯
        }
        尝试每一种可能  //for 循环
        {
    		满足check条件//if
            标记 //  bool st[]
            继续下一步 dfs(step+1)
            恢复初始状态(回溯的时候要用到)
        }
        
    }
    
  • BFS

    • 前引

      一般使用队列来实现;

      BFS一般用于求最短路问题,边权为1

    • 步骤设计

      1. 确定该题目的状态(包括边界)
      2. 找到状态转移方式
      3. 找到问题的出口,计数或者某一个状态
      4. 设计搜索

      和前面的差不多,一般情况下,BFS 和 DFS 可以互换

    • 注意

      1. BFS=队列
      2. BFS:逐层扩展下一层,把扩展出的下一层状态放进队列中处理
      3. 如果这些状态有相同的,只需要搜一次,只需要进入队列一次
      4. 必须判重

1.乳草的入侵

  • 题目

    链接: 189. 乳草的入侵 - AcWing题库

    农民约翰一直努力让他的草地充满鲜美多汁而又健康的牧草。

    可惜天不从人愿,他在植物大战人类中败下阵来。

    邪恶的乳草已经在他的农场的西北部份占领了一片立足之地。

    草地像往常一样,被分割成一个高度为 Y,宽度为 X 的直角网格。

    (1,1)是左下角的格(也就是说坐标排布跟一般的 X,Y 坐标相同)。

    乳草一开始占领了格 (Mx,My)。

    每个星期,乳草传播到已被乳草占领的格子四面八方的每一个没有很多石头的格(包括垂直与水平相邻的和对角线上相邻的格)内。

    1 周之后,这些新占领的格又可以把乳草传播到更多的格里面了。

    达达想要在草地被乳草完全占领之前尽可能的享用所有的牧草。

    她很好奇到底乳草要多久才能占领整个草地。

    如果乳草在 0 时刻处于格 (Mx,My),那么几个星期以后它们可以完全占领入侵整片草地呢(对给定的数据总是会发生)?

    在草地地图中,. 表示草,而 * 表示大石。

    比如这个 X=4,Y=3 的例子。

    ....
    ..*.
    .**.
    

    如果乳草一开始在左下角(第 1 排,第 1 列),那么草地的地图将会以如下态势发展:

          ....  ....  MMM.  MMMM  MMMM  
          ..*.  MM*.  MM*.  MM*M  MM*M  
          M**.  M**.  M**.  M**.  M**M  
    星期数  0     1     2     3     4
    

    乳草会在 4 星期后占领整片土地。

    输入格式

    第 1 行: 四个由空格隔开的整数: X, Y, Mx, My

    第 2 到第 Y+1 行: 每行包含一个由 X 个字符(. 表示草地,* 表示大石)构成的字符串,共同描绘了草地的完整地图。

    输出格式

    输出一个整数,表示乳草完全占领草地所需要的星期数。

    数据范围

    1≤X,Y≤100

    输入样例:

    4 3 1 1
    ....
    ..*.
    .**.
    

    输出样例:

    4
    
  • 前n次 AC 0%

    #include<bits/stdc++.h>
    using namespace std;
    
    typedef pair<int,int> PII;
    
    const int N=110;
    
    int n,m,a,b;
    
    char g[N][N];
    int d[N][N];
    
    int dx[8]={0,0,-1,1,-1,1,-1,1},dy[8]={1,-1,0,0,1,1,-1,-1};
    
    bool check()  //判断是否满足条件,除了石头都是乳草
    {
        for(int i=1;i<=n;i++)
            for(int j=1;j<=m;j++)
                if(g[i][j]=='.')
                    return false;
        return true;
    }
    
    void f()  //输出调式用的
    {
        for(int i=1;i<=n;i++)
        {
            for(int j=1;j<=m;j++)
            {
                cout<<g[i][j];
            }
            cout<<endl;
        }
        cout<<endl;
    }
    
    void bfs()
    {
        memset(d,-1,sizeof d);  //初始化
        
        int cnt=0;  //扩展的次数
        
        queue<PII> q;
        q.push({m-b+1,a});
        
        d[m-b+1][a]=0;
        
        //下面几乎全错,没想出来怎么一次性扩展一层
        while(q.size())
        {
            auto t=q.front();
            q.pop();
            int flag=0;
            for(int i=0;i<8;i++)
            {
                
                int x=t.first+dx[i],y=t.second+dy[i];
                if(d[x][y]==-1&&x>=1&&y>=1&&x<=n&&y<=m&&g[x][y]!='*')
                {
                    flag=1;
                    q.push({x,y});
                    d[x][y]=d[t.first][t.second]+1;
                    g[x][y]='M';
                    
                }
                if(flag) cnt++;
                if(check())
                    {
                        cout<<cnt;
                        return ;
                    }
            }
        }
        
    }
    
    int main()
    {
        cin>>n>>m>>a>>b;
        
        for(int i=1;i<=n;i++)
            for(int j=1;j<=m;j++)
                cin>>g[i][j];  //看题,起点应该从1开始,存图
                
        g[m-b+1][a]='M';  //地图的坐标 (1,1)在右下角,(a,b)在二维数组里面的表示,在纸上举个例子,模拟一下,硬想我是真不行
        
        bfs();
        
        return 0;
    }
    
  • 模仿正确的题解写的 AC 0%

    #include<bits/stdc++.h>
    using namespace std;
    
    typedef pair<int,int> PII;
    
    const int N=110;
    
    int n,m;
    int ans,cnt;
    PII st;
    char g[N][N];
    int d[N][N],vis[N][N];
    int dx[8]= {1,-1,0,0,1,-1,1,-1}, dy[8]= {0,0,1,-1,1,-1,-1,1};
    
    void bfs()
    {
        queue<PII> q;
        q.push(st);
        
        d[st.first][st.second]=0;
        vis[st.first][st.second]=1;
        
        while(q.size())
        {
            auto t=q.front();
            q.pop();
            
            for(int i=0;i<8;i++)
            {
                int x=st.first+dx[i],y=st.second+dy[i];
                if(!vis[x][y]&&x>=1&&x<=n&&y>=1&&y<=m&&g[x][y]!='*')
                {
                    cnt--;
                    vis[x][y]=1;
                    q.push({x,y});
                    d[x][y]=d[t.first][t.second]+1;
                    ans=max(ans,d[x][y]);
                    if(cnt==0) 
                        return ;
                }
            }
        }
    }
    
    
    int main()
    {
        scanf("%d%d%d%d\n",&n,&m,&st.second,&st.first);
        
        
        for(int i=n;i>=1;i--)
            for(int j=1;j<=m;j++)
            {
                cin>>g[i][j];
                if(g[i][j]=='.')
                    cnt++;
            }
            
        for(int i=1;i<=n;i++)
            for(int j=1;j<=m;j++)
            cout<<g[i][j];
            cout<<endl;
            
        if(g[st.first][st.second]=='.') 
            cnt--;
        
        bfs();
        
        cout<<ans;
        
        return 0;
    }
    

    不知道哪错了 Debug 中

  • 正确代码

    #include <bits/stdc++.h>
    using namespace std;
    #define fir(i,a,b) for(int i=a;i<=b;i++)
    #define pii pair<int,int>
    #define mk(a,b) make_pair(a,b)
    const int dx[8]= {1,-1,0,0,1,-1,1,-1};
    const int dy[8]= {0,0,1,-1,1,-1,-1,1};
    const int N=110;
    pii st,now;
    char s[N][N];
    int cnt,n,m,vis[N][N],ans,dis[N][N];
    queue<pii> q;
    int check(int x,int y)//判断:在范围;没有被访问过;不是石头
    {
        return x>=1 && x<=n && y>=1 && y<=m && vis[x][y]==0 && s[x][y]!='*';
    }
    int bfs()
    {
        q.push(st);
        dis[st.first][st.second]=0;
        vis[st.first][st.second]=1;
        while(q.size())
        {
            now=q.front();
            q.pop();
            fir(i,0,7)
            {
                int x=now.first+dx[i],y=now.second+dy[i];//拓展
                if (check(x,y))
                {
                    cnt--;
                    vis[x][y]=1;
                    dis[x][y]=dis[now.first][now.second]+1;
                    ans=max(ans,dis[x][y]);//找出最大的dis,也就是最后答案
                    q.push(mk(x,y));
                    if (cnt==0)//所有的草地被占满了.
                        return 1;
                }
            }
        }
    }
    int main()
    {
        scanf("%d%d%d%d\n",&m,&n,&st.second,&st.first);//读入真是博大精深啊!!!!!
        for(int i=n; i>=1; i--)
        {
            for(int j=1; j<=m; j++)
            {
                s[i][j]=getchar();
                if (s[i][j]=='.')
                    cnt++;//统计有多少个空
            }
            getchar();
        }
        if (s[st.first][st.second]=='.')//刚开始就有一根乳草.
            cnt--;
        bfs();
        cout<<ans;
    }
    
  • 反思

    今天晚上没课,四个小时就做这个题,最后还没做出来

    • 往外扩展几层,直接就是 最短距离 d[x]

    最大的收获就是 (1,1)在左下角的坐标的表示,详细看代码

    • 中间有一次,考虑这个问题,但只是仅仅想到一个起始点的坐标,没考虑全面,整个数组都是

    今天的时间真的浪费掉了,应该及时看题解的

有关蓝桥杯刷题冲刺 | 倒计时18天的更多相关文章

  1. ruby - i18n Assets 管理/翻译 UI - 2

    我正在使用i18n从头开始​​构建一个多语言网络应用程序,虽然我自己可以处理一大堆yml文件,但我说的语言(非常)有限,最终我想寻求外部帮助帮助。我想知道这里是否有人在使用UI插件/gem(与django上的django-rosetta不同)来处理多个翻译器,其中一些翻译器不愿意或无法处理存储库中的100多个文件,处理语言数据。谢谢&问候,安德拉斯(如果您已经在ruby​​onrails-talk上遇到了这个问题,我们深表歉意) 最佳答案 有一个rails3branchofthetolkgem在github上。您可以通过在Gemfi

  2. ruby-on-rails - Rails 3 I18 : translation missing: da. datetime.distance_in_words.about_x_hours - 2

    我看到这个错误:translationmissing:da.datetime.distance_in_words.about_x_hours我的语言环境文件:http://pastie.org/2944890我的看法:我已将其添加到我的application.rb中:config.i18n.load_path+=Dir[Rails.root.join('my','locales','*.{rb,yml}').to_s]config.i18n.default_locale=:da如果我删除I18配置,帮助程序会处理英语。更新:我在config/enviorments/devolpment

  3. ruby-on-rails - 如果我将 ruby​​ 版本 2.5.1 与 rails 版本 2.3.18 一起使用会怎样? - 2

    如果我使用ruby​​版本2.5.1和Rails版本2.3.18会怎样?我有基于rails2.3.18和ruby​​1.9.2p320构建的rails应用程序,我只想升级ruby的版本,而不是rails,这可能吗?我必须面对哪些挑战? 最佳答案 GitHub维护apublicfork它有针对旧Rails版本的分支,有各种变化,它们一直在运行。有一段时间,他们在较新的Ruby版本上运行较旧的Rails版本,而不是最初支持的版本,因此您可能会发现一些关于需要向后移植的有用提示。不过,他们现在已经有几年没有使用2.3了,所以充其量只能让更

  4. ruby-on-rails - Ruby on Rails I18n 插值 - 2

    大家好!我对我的:username字段进行了一个小的验证,它应该是4到30个字符。我写了一个验证::length=>{:within=>4..30,:message=>I18n.t('activerecord.errors.range')-我想显示一个错误各种错误的消息(不像,太长或太短),但这里有一个问题-我可以将最小值和最大值都传递给翻译,以便有类似的东西:用户名应该在4到30个字符之间。目前我有:range:"shouldbebetween%{count}and%{count}characters",这显然不起作用(只是为了检查)。是否可以从范围中获取这些值?谢谢大家的指教!

  5. ruby - Ruby 性能中的计时器 - 2

    我正在寻找一个用ruby​​演示计时器的在线示例,并发现了下面的代码。它按预期工作,但这个简单的程序使用30Mo内存(如Windows任务管理器中所示)和太多CPU有意义吗?非常感谢deftime_blockstart_time=Time.nowThread.new{yield}Time.now-start_timeenddefrepeat_every(seconds)whiletruedotime_spent=time_block{yield}#Tohandle-vesleepinteravalsleep(seconds-time_spent)iftime_spent

  6. ruby-on-rails - 如果特定语言环境中缺少翻译,如何配置 i18n 以使用 en 语言环境? - 2

    如果特定语言环境中缺少翻译,如何配置i18n以使用en语言环境翻译?当前已插入翻译缺失消息。我正在使用RoR3.1。 最佳答案 找到相似的question这里是答案:#application.rb#railswillfallbacktoconfig.i18n.default_localetranslationconfig.i18n.fallbacks=true#railswillfallbacktoen,nomatterwhatissetasconfig.i18n.default_localeconfig.i18n.fallback

  7. ruby-on-rails - i18n 与枚举 gem - 2

    我正在使用Enumerizegemhttps://github.com/brainspec/enumerize/它允许我以简单的形式使用漂亮的选择。并且此选择中的所有选项均已翻译。en:enumerize:user:sex:male:'Man'female:'Woman'所以,在我的表单中,我选择了变体“男人”和“女人”。当我用“男人”值保存记录时,我得到了“男性”值的性别属性。现在我想在显示页面上将该值显示为“Man”,但是=@user.sex输出为'male'而不是'Man' 最佳答案 我可能会使用.text方法(您可以通过使用

  8. iNFTnews | 周杰伦18年前未发布的作品Demo,藏在了区块链技术里 - 2

    当音乐碰上区块链技术,会擦出怎样的火花?或许周杰伦已经给了我们答案。8月29日下午,B站独家首发周杰伦限定珍藏Demo独家访谈VCR,周杰伦在VCR里分享了《晴天》《青花瓷》《搁浅》《爱在西元前》四首经典歌曲Demo背后的创作故事,并首次公布18年前未发布的神秘作品《纽约地铁》的Demo。在VCR中,方文山和杰威尔音乐提及到“多亏了区块链技术,现在我们可以将这些Demos,变成独一无二具有收藏价值的艺术品,这些Demos可以在薄盒(国内数藏平台)上听到。”如何将音乐与区块链技术相结合,薄盒方面称:“薄盒作为区块链技术服务方,打破传统对于区块链技术只能作为数字收藏的理解。聚焦于区块链技术赋能,在

  9. 蓝桥杯备赛(二) - 2

    目录前言: 一、ASC分析代码实现二、 卡片分析代码实现三、 直线分析代码实现四、货物摆放分析代码实现小结:前言:  在刷题的过程中,发现蓝桥杯的题目和力扣的差别很大。让人有一种不一样的感觉,蓝桥杯题目偏向对于实际问题用编程去的解决,而力扣给人感觉很锻炼自己的编程思维,逻辑能力。两者结合去刷,相信会有不一样的收获。 一、ASC  已知大写字母A的ASCII码为65,请问大写字母L的ASCII码是多少?分析  这道题目看上去很简单,我们需确定自己计算的准确,所以我建议用编程去解决。代码实现publicclassTest8{publicstaticvoidmain(String[]args){Sy

  10. ruby-on-rails - 具有管理 namespace 的 Rails 3 中的 I18n - 2

    我正在根据Rails指南的建议开发Rails应用程序,以创建包含翻译的文件夹树和文件。我的文件夹树与此类似:|-defaults|---es.rb|---en.rb|-models|---book|-----es.rb|-----en.rb|-views|---defaults|-----es.rb|-----en.rb|---books|-----es.rb|-----en.rb|---users|-----es.rb|-----en.rb|---navigation|-----es.rb|-----en.rbconfig/locales/views/books/en.yml中的内容

随机推荐