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

相关推荐
金銀銅鐵10 小时前
[Java] 用图形化界面演示 iadd, isub, iconst_<i> 指令的效果
java·后端·python
J2虾虾11 小时前
Spring AI Alibaba文档
java·人工智能·spring
YikNjy11 小时前
break和continue
java·开发语言·算法
SomeOtherTime11 小时前
Geojson相关(AI回答)
java·前端·python
日月云棠11 小时前
10 Integer —— 最常用的整数包装类深度解析
java·后端
秋911 小时前
java项目中cpu飙升排查及解决方法
java·开发语言
野生技术架构师11 小时前
牛客网2026最新大厂Java高频面试题精选(附标准答案)
java·开发语言
PH = 711 小时前
JAVA的SPI机制
java·开发语言
一 乐11 小时前
高校实习信息发布网站|基于Spring Boot的高校实习信息发布网站的设计与实现(源码+数据库+文档)
java·数据库·spring boot·后端·论文·毕设·高校实习信息发布网站
weelinking11 小时前
【产品】11_实现后端接口——数据在背后如何流动
java·人工智能·python·sql·oracle·json·ai编程