CSP认证-第四次培训(2019.9.11)

B题 碰撞的小球

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

简单模拟题。具体思路详见注释。

#include <bits/stdc++.h>
using namespace std;
struct node
{
    int pos,d;//球的位置,方向
}a[110];
int n,t,l,tmp;
int main()
{
    ios::sync_with_stdio(false);
    cin>>n>>l>>t;
    for(int i=1;i<=n;i++)
    {
        cin>>a[i].pos;
        a[i].d=1;//初始方向均向右,每秒位置加上d(d只能等于1或-1)
    }
    for(int i=1;i<=t;i++)//遍历时间
    {
        for(int j=1;j<=n;j++)//遍历单个小球,处理碰墙情况
        {
            tmp=a[j].pos+a[j].d;
            if(tmp==l||tmp==0){a[j].pos=tmp;a[j].d=(-a[j].d);}//碰到墙,反向
            else a[j].pos+=a[j].d;//未碰墙,按原方向移动一个单位长度
        }
        for(int j=1;j<=n;j++)//遍历寻找两个相同位置的小球,处理两球相撞情况
            for(int k=j+1;k<=n;k++)
            {
                if(a[j].pos==a[k].pos)//两球相撞,两球均反向
                {
                    a[j].d=(-a[j].d);
                    a[k].d=(-a[k].d);
                }
            }
    }
    for(int i=1;i<=n;i++)
        i==n?printf("%d\n",a[i].pos):printf("%d ",a[i].pos);
    return 0;
}

D题 消除类游戏

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
数据很小,直接暴力。

100分 AC代码:

#include <cstdio>
#include <iostream>
using namespace std;
bool vis[40][40];
int n,m,x1,x2,y1,y2,tmp,a[40][40];
int main()
{
    ios::sync_with_stdio(false);
    cin>>n>>m;
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
        cin>>a[i][j];
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
        {
            tmp=0;x1=x2=i;//记得初始化x1、x2(x1、x2为竖行可以消去的区间)
            for(int k=i;k<=n;k++)
            {
                if(a[k][j]==a[i][j]){x2=k;tmp++;}
                else break;
            }
            for(int k=i-1;k>=1;k--)
            {
                if(a[k][j]==a[i][j]){x1=k;tmp++;}
                else break;
            }
            if(tmp>=3)
            {
                for(int k=x1;k<=x2;k++)
                    vis[k][j]=1;
            }
            tmp=0;y1=y2=j;//记得初始化y1、y2(y1、y2为横行可以消去的区间)
            for(int k=j;k<=m;k++)
            {
                if(a[i][k]==a[i][j]){y2=k;tmp++;}
                else break;
            }
            for(int k=j-1;k>=1;k--)
            {
                if(a[i][k]==a[i][j]){y1=k;tmp++;}
                else break;
            }
            if(tmp>=3)
            {
                for(int k=y1;k<=y2;k++)
                    vis[i][k]=1;
            }
        }
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
        {
            if(vis[i][j]==1)a[i][j]=0;
            j==m?printf("%d\n",a[i][j]):printf("%d ",a[i][j]);
        }
    return 0;
}

A题 跳一跳

在这里插入图片描述
100分 AC代码:

#include <bits/stdc++.h>
using namespace std;
int opt,x,ans;
int main()
{
    ios::sync_with_stdio(false);
    x=1;ans=0;
    while(cin>>opt&&opt)
    {
        if(opt==1)x=1;
        else
        {
            if(x==1)x=2;
            else x+=2;
        }
        ans+=x;
    }
    printf("%d\n",ans);
    return 0;
}

C题 数位之和

在这里插入图片描述
100分 AC代码:

#include <bits/stdc++.h>
using namespace std;
int n,d,ans;
int main()
{
    ios::sync_with_stdio(false);
    cin>>n;
    while(n)
    {
        d=n%10;
        ans+=d;
        n=n/10;
    }
    printf("%d\n",ans);
    return 0;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

nefu-ljw

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值