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 是最方便的,其他的输入方式挺麻烦。

相关推荐
咕白m6251 小时前
Java 实现 Excel 转 HTML:完整示例
java
RealPluto2 小时前
Spring AOP 失效排查
java·spring
码路飞3 小时前
热榜全是 OpenClaw,但我用 50 行 Python 就造了个桌面 AI Agent 🤖
java·javascript
Nyarlathotep01133 小时前
LinkedList源码分析
java·后端
用户8307196840823 小时前
Java 告别繁琐数据统计代码!MySQL 8 窗口函数真香
java·sql·mysql
带刺的坐椅3 小时前
SolonCode v0.0.20 发布 - 编程智能体(新增子代理和浏览器能力)
java·ai·agent·solon·solon-ai·claude-code·openclaw
会员源码网5 小时前
数字格式化陷阱:如何优雅处理 NumberFormatException
java
孔明click335 小时前
Sa-Token v1.45.0 发布 🚀,正式支持 Spring Boot 4、新增 Jackson3/Snack4 插件适配
java·sa-token·开源·springboot·登录·权限认证
程序猿阿越6 小时前
Kafka4源码(二)创建Topic
java·后端·源码阅读
悟空码字6 小时前
Spring Boot 整合 MongoDB 最佳实践:CRUD、分页、事务、索引全覆盖
java·spring boot·后端