xtu oj 交叉点

文章目录

回顾

前言

偏移量的问题

代码

cpp 复制代码
#include<stdio.h>
#define N 40

char s[N][N];

int get_ans(int x,int y,int dx,int dy){//判断行,列,斜方向能不能构成连续的三个棋子,假设可以返回 1 
	int cnt=0;//x,y 表示给定的点的坐标,dx 和 dy 表示偏移量,cnt 表示连续的棋子的个数
	
	for(int i=-2;i<=2;i++){
		int hhh_x=x+i*dx;
		int hhh_y=y+i*dy;//表示更新之后的点的坐标
		
		if(s[hhh_x][hhh_y]=='*'){//假设是棋子
			cnt++;
			if(cnt>=3){
				return 1;
			}
		}else{
			cnt=0;//是空格就中断计数器,重新开始计数
		}
	}
	
	return 0;
}

int main(){
	int t;
	int qaq=1;//为了输出 case 进行到哪儿了
	scanf("%d",&t);
	while(t--){
		for(int i=0;i<N;i++){//把没用到的都初始化为空格
			for(int j=0;j<N;j++){
				s[i][j]='.';
			}
		}
		
		int n,m;
		scanf("%d%d",&n,&m);
		for(int i=2;i<n+2;i++){//输入的时候就防止下标越界
			scanf("%s",s[i]+2);
		}
		
	
		int num=0;//存交叉点的数目
		int x[N*N];
		int y[N*N];//注意所有点都可能是交叉点,极端情况是所有点都是棋子,n*m 个交叉点
		
		for(int i=2;i<n+2;i++){
			for(int j=2;j<m+2;j++){
				if(s[i][j]=='*'){
					int ans=0;//表示的是行,列,对角线,四个方向有几个方向满足条件,最开始是 0 ,表示没有方向
					//满足条件
					ans+=get_ans(i,j,0,1);//行
					ans+=get_ans(i,j,1,0);//列
					ans+=get_ans(i,j,1,1);//左上到右下
					ans+=get_ans(i,j,1,-1);//左下到右上
					
					if(ans>=2){//假设有两个方向满足条件,就表示该点是交叉点
						x[num]=i-2;
						y[num]=j-2;
						num++;
					}
				}
			}
		}
		
		//下面是输出
		printf("Case %d:%d\n",qaq,num);
		qaq++;
		
		for(int i=0;i<num;i++){
			printf("%d %d\n",x[i],y[i]);
		}
	}
	
	return 0;
}

思路

之前图方便,代码块之间都没有空行,还是空行好一些,能带来更好的阅读体验。感觉这种位置偏移量的题非常经典,这个模拟题也是非常经典。输入的时候,每次碰到这种二维数组我都非常害怕,刚刚搜了一下好像就用这种 %s 是最方便的,其他的输入方式挺麻烦。

相关推荐
码路飞3 小时前
GPT-5.3 Instant 终于学会好好说话了,顺手对比了下同天发布的 Gemini 3.1 Flash-Lite
java·javascript
SimonKing3 小时前
OpenCode AI编程助手如何添加Skills,优化项目!
java·后端·程序员
Seven975 小时前
剑指offer-80、⼆叉树中和为某⼀值的路径(二)
java
怒放吧德德16 小时前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty
雨中飘荡的记忆18 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
心之语歌20 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
华仔啊21 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang21 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
Ray Liang1 天前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
Java水解1 天前
Java 中间件:Dubbo 服务降级(Mock 机制)
java·后端