题解:ABC320C - Slot Strategy 2 (Easy)

题解:ABC 320C - Slot Strategy 2 (Easy)

·题目

链接:Atcoder

链接:洛谷

·难度

算法难度:C。

思维难度:C。

调码难度:B。

综合评价:普及-。

·算法

枚举+模拟。

·思路

先遍历最后每个转盘上的数,如果这个数(记作i)分别在a、b、c中出现过就说明最后有可能是这个数。接下来遍历每一秒按照优先级,优先级高的如果还没有停止转动并且现在停止显示数字正好为i,就停止他,否则看下一个(优先级次高的)。优先级直接复制粘贴6个循环。

·代价

O(m),其他的遍历全是常数,只有对于每种情况答案的遍历最坏情况下为3m。

·细节

求答案的循环里判断出口用"三个转盘是否都停止了"来判断。

·代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
string a="",b="",c="";
int m=0;
bool x[10]={},y[10]={},z[10]={};
int main(){
    scanf("%d",&m);
    cin>>a>>b>>c;
    for(int i=0;i<m;i++){
        x[a[i]-'0']=true;
        y[b[i]-'0']=true;
        z[c[i]-'0']=true;
    }
    //输入,并记录每个数在相应转盘上是否出现
    int tans=1<<30;
    for(int i=0;i<10;i++){
        if(x[i]==true&&y[i]==true&&z[i]==true){
            //都出现过,有可能作为最后答案
            int ans=0;
            bool f=false,g=false,h=false;
            //ans:本次所用时间;f、g、h:分别记录每个转盘是否已经停止
            ans=0;
            f=false,g=false,h=false;
            for(int j=0;f==false||g==false||h==false;j++){
                //遍历每一秒
                if(a[j%m]==i+'0'&&f==false){
                    f=true;
                    //最高优先级先判断
                }
                else if(b[j%m]==i+'0'&&g==false){
                    g=true;
                    //次高
                }
                else if(c[j%m]==i+'0'&&h==false){
                    h=true;
                    //最低
                }
                ans=j;
                //更新答案
            }
            tans=min(tans,ans);
            //答案取最优值,后同理
            ans=0;
            f=false,g=false,h=false;
            for(int j=0;f==false||g==false||h==false;j++){
                if(a[j%m]==i+'0'&&f==false){
                    f=true;
                }
                else if(c[j%m]==i+'0'&&h==false){
                    h=true;
                }
                else if(b[j%m]==i+'0'&&g==false){
                    g=true;
                }
                ans=j;
            }
            tans=min(tans,ans);
            ans=0;
            f=false,g=false,h=false;
            for(int j=0;f==false||g==false||h==false;j++){
                if(c[j%m]==i+'0'&&h==false){
                    h=true;
                }
                else if(a[j%m]==i+'0'&&f==false){
                    f=true;
                }
                else if(b[j%m]==i+'0'&&g==false){
                    g=true;
                }
                ans=j;
            }
            tans=min(tans,ans);
            ans=0;
            f=false,g=false,h=false;
            for(int j=0;f==false||g==false||h==false;j++){
                if(c[j%m]==i+'0'&&h==false){
                    h=true;
                }
                else if(b[j%m]==i+'0'&&g==false){
                    g=true;
                }
                else if(a[j%m]==i+'0'&&f==false){
                    f=true;
                }
                ans=j;
            }
            tans=min(tans,ans);
            ans=0;
            f=false,g=false,h=false;
            for(int j=0;f==false||g==false||h==false;j++){
                if(b[j%m]==i+'0'&&g==false){
                    g=true;
                }
                else if(a[j%m]==i+'0'&&f==false){
                    f=true;
                }
                else if(c[j%m]==i+'0'&&h==false){
                    h=true;
                }
                ans=j;
            }
            tans=min(tans,ans);
            ans=0;
            f=false,g=false,h=false;
            for(int j=0;f==false||g==false||h==false;j++){
                if(b[j%m]==i+'0'&&g==false){
                    g=true;
                }
                else if(c[j%m]==i+'0'&&h==false){
                    h=true;
                }
                else if(a[j%m]==i+'0'&&f==false){
                    f=true;
                }
                ans=j;
            }
            tans=min(tans,ans);
        }
    }
    if(tans==1<<30){
        tans=-1;
    }
    //特判没有答案的情况
    printf("%d\n",tans);
    return 0;
}

·注意

循环内部要用if{}else if{}else{},否则会出现一秒停多个转盘的情况。

相关推荐
mjhcsp27 分钟前
C++ 三分查找:在单调与凸函数中高效定位极值的算法
开发语言·c++·算法
立志成为大牛的小牛33 分钟前
数据结构——四十二、二叉排序树(王道408)
数据结构·笔记·程序人生·考研·算法
Elnaij2 小时前
从C++开始的编程生活(13)——list和浅谈stack、queue
开发语言·c++
Funny_AI_LAB3 小时前
李飞飞联合杨立昆发表最新论文:超感知AI模型从视频中“看懂”并“预见”三维世界
人工智能·算法·语言模型·音视频
RTC老炮6 小时前
webrtc降噪-PriorSignalModelEstimator类源码分析与算法原理
算法·webrtc
深思慎考6 小时前
微服务即时通讯系统(服务端)——用户子服务实现逻辑全解析(4)
linux·c++·微服务·云原生·架构·通讯系统·大学生项目
草莓火锅7 小时前
用c++使输入的数字各个位上数字反转得到一个新数
开发语言·c++·算法
j_xxx404_8 小时前
C++ STL:阅读list源码|list类模拟|优化构造|优化const迭代器|优化迭代器模板|附源码
开发语言·c++
散峰而望8 小时前
C/C++输入输出初级(一) (算法竞赛)
c语言·开发语言·c++·算法·github
Kuo-Teng8 小时前
LeetCode 160: Intersection of Two Linked Lists
java·算法·leetcode·职场和发展