C+D两道大水题。。。C纯粹细节问题,暴力可过;D做过,遍历统计即可
C 输出练习
题目链接:https://ac.nowcoder.com/acm/contest/43844/C
呜呜呜,纯纯大水题,打的时候没看出来,其实暴力蛮快的,同时就是注意细节问题哈,因为这里最好单独判断k=0和k=1的情况,剩下的k一种情况。多说无益,上代码!
#include<iostream> #include<cstdio> #include<string> #include<cstring> #include<algorithm> #include<cmath> #include<map> #include<vector> #define ll long long #define ull unsigned long long #define mem(x,y) memset(x,y,sizeof(x)) //#define int long long inline ll read() { ll x=0,f=1;char ch=getchar(); while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();} while (ch>='0'&&ch<='9'){x=x*10+ch-48;ch=getchar();} return x*f; } using namespace std; const int maxm=2e5+5,inf=0x3f3f3f3f; ll l,r,k; void solve(){ bool flag=true; cin>>l>>r>>k; if(k==0){ if(l==0&&r==0){ cout<<0<<endl; } else if(l==0&&r>=1){ cout<<"0 1"<<endl; } else if(l==1) cout<<"1\n"; else cout<<"None.\n"; return ; } else if(k==1){ if(l<=1&&r>=1){ cout<<1<<endl; } else cout<<"None.\n"; return ; } //k>=2 ll now=1; while(now<=r){ if(now>=l){ cout<<now<<' '; flag=false; } if(now<=r/k) //此处用来判读是否会爆long long now*=k; //除法的思想学一学 else break; // } if(flag) cout<<"None."; cout<<endl; return ; } signed main(){ // ios::sync_with_stdio(false),cin.tie(0),cout.tie(0); int _=1; cin>>_; while(_--){ solve(); } return 0; }
D 国际象棋
题目链接:https://ac.nowcoder.com/acm/contest/43844/D
D题做过其实。。。只能说打的时候手不够快,脑子不够灵光。
打的时候错误原因是算法假了,我仅仅判断当前放入点的八个方向,以当前点为起点,这样是存在问题的。事实上我们需要在每放入一个棋子后判断整个棋盘的k子连珠状态,但是那样的话容易超时,而且也是一种赘余的操作。因为放入的棋子仅仅会改变当前位置的八个方向的k子连珠的成功性,所以只需要判断以当前落入子的位置作为k子的一部分,在8个方向遍历,之后判断4个大方向的最长连珠能否超过k即可。
当然,遍历8个方向的时候取个负就可以变成遍历4个正负方向。
#include<iostream> #include<cstdio> #include<string> #include<cstring> #include<algorithm> #include<cmath> #include<map> #include<vector> #define ll long long #define ull unsigned long long #define mem(x,y) memset(x,y,sizeof(x)) //#define int long long inline ll read() { ll x=0,f=1;char ch=getchar(); while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();} while (ch>='0'&&ch<='9'){x=x*10+ch-48;ch=getchar();} return x*f; } using namespace std; const int maxm=1e3+5,inf=0x3f3f3f3f; int n,m,k,t,a[maxm][maxm],cnt[maxm],ans=-1,fx[8]={-1,-1,0,1,1,1,0,-1},fy[8]={0,1,1,1,0,-1,-1,-1}; bool flag=true; bool check(int x,int y){ return (x>=1&&x<=n&&y>=1&&y<=m); } bool calc(int x,int y){ int xx=x,yy=y,cnt=0,sum[8]={0,0,0,0,0,0,0,0}; for(int i=0;i<8;++i){ xx=x,yy=y,cnt=0; while(a[xx][yy]==a[x][y]&&check(xx,yy)){ ++cnt; xx+=fx[i]; yy+=fy[i]; } sum[i]=cnt; } if(k<=sum[0]+sum[4]-1||k<=sum[1]+sum[5]-1||k<=sum[2]+sum[6]-1||k<=sum[3]+sum[7]-1){ flag=false; return true; } return false; } void solve(){ cin>>n>>m>>k>>t; int p; flag=true; for(int i=1;i<=t;++i){ cin>>p; if(i%2&&flag){//奇黑 a[n-cnt[p]][p]=1; if(calc(n-cnt[p],p)) ans=i; ++cnt[p]; }else if(flag){//偶白 a[n-cnt[p]][p]=2; if(calc(n-cnt[p],p)) ans=i; ++cnt[p]; } } cout<<ans<<endl; return ; } signed main(){ // ios::sync_with_stdio(false),cin.tie(0),cout.tie(0); int _=1; // cin>>_; while(_--){ solve(); } return 0; }标签:ch,59,ll,long,牛客,while,小白月赛,include,define From: https://www.cnblogs.com/Qiansui/p/16837714.html