题解 | 牛客周赛 Round 19

小红的字符串大小写变换

https://ac.nowcoder.com/acm/contest/69117/A

牛客周赛 Round 19全部题解

A.小红的字符串大小写变换

本题考察简单模拟 我们只需要按照题目意思执行即可,可以使用toupper和tolower函数来帮助我们

void solve()
{
    cin>>n>>m;
    string s; cin>>s;
    for(int i=0;s[i];i++){
        if(i<m) s[i]=toupper(s[i]);
        else s[i]=tolower(s[i]);
    }
    cout<<s<<endl;
    return ;
}

B.小红杀怪

本题考察暴力枚举 我们可以发现题目有两种操作,同时范围很小考虑暴力枚举,对于选择两个选择我们可以固定一个选择来求另一个选择即可,然后按照题目意思处理,我们固定群体伤害,这样即使数据范围扩大我们也是o(n)

void solve()
{
    int a,b,x,y; cin>>a>>b>>x>>y;
    
    int ans=20;// 相对最大值
    for(int i=0;i<=20;i++){
        int aa=a-i*y,bb=b-i*y;
        int res=i;
        if(aa>0) res+=ceill(1.0*aa/x);
        if(bb>0) res+=ceill(1.0*bb/x);
        ans=min(ans,res);
    }
    cout<<ans<<endl;
    return ;
}

小红的元素分裂

考察简单dp?

1. 实现1

目标是全部变成1,所以我们是1的时候直接初始值为0即可,然后我们发现每一个数可以分裂为两个乘积为x的约数,然后我们直接枚举所有约数即可然后看哪一种情况最优即可

时间复杂度:n*sqrt(n)


void solve()
{
    cin>>n;
     
    memset(dp,0x3f,sizeof dp);
    dp[1]=0;
    for(int i=2;i<N;i++){
        dp[i]=dp[i-1]+1;
        for(int j=2;j<=i/j;j++){
            if(i%j==0){
                dp[i]=min(dp[i],dp[j]+dp[i/j]+1);
            }
        }
    }    
    int ans=0;
    while(n--){
        int x; cin>>x;
        ans+=dp[x];
    }
    cout<<ans<<endl;
     
    return ;

2. 实现2

我们可以采用记忆化搜索的方式每个点也只会走一次时间复杂度同上

int dfs(int x){
    int&v=dp[x];
    if(~v) return v;
    v=INF;
    v=min(v,dfs(x-1)+1);
    for(int i=2;i<=x/i;i++){
        if(x%i==0){
             v=min(v,dfs(i)+dfs(x/i)+1);
        }
    }
    return v;
}
void solve()
{
    memset(dp,-1,sizeof dp);
    dp[1]=0;
    cin>>n;
    int ans=0;
    while(n--){
        int x; cin>>x;
        ans+=dfs(x);
    }
    cout<<ans<<endl;
     
    return ;
}

D.小红的扫雷游戏

考察暴力搜索以及题意理解 我们可以发现对于一个地方要填X是必须在所有的情况下都必须填X,这具有填X的唯一性,上面意思呢?也就是对于满足题目要求的可能有很多种情况比如

...
1.1
... 
的答案可以是
...
1.1
X.X 

也可以是
...
1X1
... 

也就是这样也是可以的
所有没有必须填X的地方

如果一个点是可能填下也可能不填X那就是.
如果不能填X那就是O

那么怎处理也就是我们找出所有情况来看一个点是不是只有一种情况即可

我们考虑收到影响的点只有在数字的9宫格内的点可以采取剪枝的做法只考虑这些点填X还是.

  for(int i=1;i<=n;i++)
        for(int j=1;j<=n;j++){
            if(isdigit(s[i][j])){
                dian.push_back({i,j});
                for(int u=0;u<8;u++){
                    int x=i+dx[u],y=j+dy[u];
                    if(x>=1 &&x<=n &&y>=1 &&y<=n &&s[x][y]=='.'){
                        S.insert({x,y});
                    }
                }
            }
        }
    for(auto&v:S) res.push_back(v);

check函数

bool check(){
    for(auto&[i,j]:dian){
        int t=s[i][j]-'0',now=0;
        for(int k=0;k<8;k++){
            int a=dx[k]+i,b= dy[k]+j;
            if(a<1 || b<1 || a>4 || b> 4) continue;
            now+=s[a][b]=='X';
        }
        if(now!=t) return false;       
    } 
    return true;
}

然后暴搜

void dfs(int u){
    if(u==res.size()){
        if(!check()) return ;
        
        for(int i=1;i<=4;i++)
            for(int j=1;j<=4;j++)
                if(!isdigit(s[i][j])){
                    if(s[i][j]=='X') yes[i][j].first=1;// 在满足要求的情况下是不是有多种可能
                    else yes[i][j].second=1;
                }
        return ;
    }
    auto [x,y]=res[u];
    s[x][y]='X';
    dfs(u+1);
    s[x][y]='.';
    dfs(u+1);
}

最后

int t,n=4,m;
char s[M][M];
set<PII> S;
int dx[8] = {-1, -1, -1, 0, 1, 1, 1, 0};
int dy[8] = {-1, 0, 1, 1, 1, 0, -1, -1};
vector<PII> res;
vector<PII> dian;
bool st[M][M];
PII yes[M][M];

bool check(){
    for(auto&[i,j]:dian){
        int t=s[i][j]-'0',now=0;
        for(int k=0;k<8;k++){
            int a=dx[k]+i,b= dy[k]+j;
            if(a<1 || b<1 || a>4 || b> 4) continue;
            now+=s[a][b]=='X';
        }
        if(now!=t) return false;       
    } 
    return true;
}

void dfs(int u){
    if(u==res.size()){
        if(!check()) return ;
        
        for(int i=1;i<=4;i++)
            for(int j=1;j<=4;j++)
                if(!isdigit(s[i][j])){
                    if(s[i][j]=='X') yes[i][j].first=1;
                    else yes[i][j].second=1;
                }
        return ;
    }
    auto [x,y]=res[u];
    s[x][y]='X';
    dfs(u+1);
    s[x][y]='.';
    dfs(u+1);
}
void solve()
{
    for(int i=1;i<=n;i++)
        for(int j=1;j<=n;j++)
             cin>>s[i][j];
    
    for(int i=1;i<=n;i++)
        for(int j=1;j<=n;j++){
            if(isdigit(s[i][j])){
                dian.push_back({i,j});
                for(int u=0;u<8;u++){
                    int x=i+dx[u],y=j+dy[u];
                    if(x>=1 &&x<=n &&y>=1 &&y<=n &&s[x][y]=='.'){
                        S.insert({x,y});
                    }
                }
            }
        }
    for(auto&v:S) res.push_back(v);
    dfs(0);
    
    for(auto [i,j]:res){
        if(yes[i][j].first==1 &&yes[i][j].second==1) s[i][j]='.';
        else if(yes[i][j].first==1) s[i][j]='X';
        else s[i][j]='O';
    }
    for(int i=1;i<=n;i++){
        for(int j=1;j<=n;j++){
           cout<<s[i][j];
        }
        cout<<endl;
    }
    return ;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
05-29 15:00
教授A:“你为什么要讲这么久,是要压缩我们对你的评议时间吗?你们别以为这样就能够让我们对你们少点意见。”&nbsp;“从你的发言和论文格式就能知道你的性格啊。”…….&nbsp;感觉被狠狠霸凌了。
码农索隆:“教授您好,首先我想回应您提出的两点疑问。” “关于我讲解时间较长的问题:这绝非为了压缩各位老师的评议时间。这份毕业设计是我过去几个月倾注了全部心血的作品,从构思、实验、调试到撰写,每一个环节都反复打磨。我深知时间宝贵,所以选择详细讲解,是希望能更完整、清晰地展示它的核心创新点、实现过程和验证结果,确保老师们能充分理解它的价值和我的努力。我完全理解并重视评审环节的意义,也做好了充分准备来听取各位老师的专业意见和批评。几个月的研究都坚持下来了,我怎么可能害怕老师们的点评呢?今天站在这里,正是抱着虚心学习、诚恳求教的态度而来。” “如果我的展示确实超时,影响了后续流程,烦请老师们随时示意,我会立刻调整。我非常期待并预留了充足的时间,希望能听到老师们宝贵的建议和深入的讨论。” “其次,关于您提到‘从发言和论文格式就能知道我的性格’。教授,我对此感到非常困惑和不安。学术研究和答辩的核心,难道不应该是作品本身的质量、逻辑的严谨性、数据的可靠性和结论的合理性吗?论文格式有明确的规范要求,我尽最大努力遵循了这些规范。如果格式上存在疏忽或不足,这属于技术性、规范性的问题,恳请老师们具体指出,我一定认真修改。但将格式问题或个人表达风格(如讲解时长)直接上升为对个人性格的评判,甚至以此作为质疑我学术态度和动机的依据,这让我感到非常不公平,也偏离了学术评议应有的客观和严谨原则。” “我尊重每一位评审老师的专业权威,也衷心希望能得到老师们对我的工作内容本身的专业指导和批评指正。任何基于研究本身的意见,无论多么尖锐,我都会认真聆听、反思并改进。但我恳请老师们,能将评议的焦点放在我的研究本身,而不是对我个人进行主观的推断或评价。谢谢各位老师。”
点赞 评论 收藏
分享
关于我大学本科四年,想了很多,但还是不知道该怎么动笔&nbsp;“大学四年,是我从懵懂少年走向职场青年的转折期。这一路跌跌撞撞,有迷茫,有遗憾,也有成长和决心。”&nbsp;大一刚进来时仍然有高中那股学习劲,经常一个人去图书馆学高等数学,但后面劲头一过便开始在宿舍开启躺平生活(现在想想那段时间真的很爽,无忧无虑)。由于大一担任班干部,所以经常要跟其他班的班干部交流,在此期间认识了隔壁班的一位女生,短发而很可爱,因为很多团建还有比赛都是我们两班一起参加的,而且我和她都是负责人,所以交集很多,后面慢慢地彼此对产生了好感,所以在大一刚开学的2个月后,我们在一起了,彼此之前都是初恋。但当时我真的是太太太直男了,对感情的想...
真烦好烦真烦:骗哥们可以,别把你自己也骗到了就行。哥们被你骗了真无所谓的,打个哈哈就过了。但希望你打完这段话后擦一下眼角,别让眼泪掉在手机屏幕上了就行。你说的这些话,哥们信一下也是没什么的。还能让你有个心里安慰,但这种话说出来骗骗兄弟就差不多得了,哥们信你一下也不会少块肉,但是你别搞得自己也当真了就行。哥们被你骗一下是真无所谓的,兄弟笑笑也就过去了。真不是哥们想要破你防,你擦擦眼泪好好想想,除了兄弟谁还会信你这些话?
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
10
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务