CSP认证 2019 12-2 回收站选址

wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

 分析:本题就是一个简单得模拟,考察对语言运用得熟练程度,由于数据量不大,直接暴力即可

#include<stdio.h>
struct coordinate{
    int x;
    int y; 
   
};
int main()
{
	int n ;
	scanf("%d",&n) ;
	coordinate cre[n] ;
	for(int i=0;i<n;i++)
		scanf("%d%d",&cre[i].x,&cre[i].y) ;
	
	int ans[5] = {0} ;
	for(int i=0;i<n;i++)
	{
		int x1 = cre[i].x ;
		int y1 = cre[i].y ;
		
		coordinate c1[4] ;
		//上 
		c1[0].x = x1+1 ;
		c1[0].y = y1 ;
		//下 
		c1[1].x = x1-1 ;
		c1[1].y = y1 ;
		//左 
		c1[2].x = x1 ;
		c1[2].y = y1-1 ;
		//右 
		c1[3].x = x1 ;
		c1[3].y = y1+1 ;
		
		int geshu = 0 ;
		for(int i=0;i<4;i++)
		{
			for(int j=0;j<n;j++)
			{
				if(c1[i].x==cre[j].x&&c1[i].y==cre[j].y)
				{
					geshu++ ;
					break ;
				}
			}
		}
		
		int score = 0 ;
		if(geshu==4)
		{
			coordinate c2[4] ;
			//左上 
			c2[0].x = x1-1 ;
			c2[0].y = y1+1 ;
			//右上 
			c2[1].x = x1+1 ;
			c2[1].y = y1+1 ;
			//左下 
			c2[2].x = x1-1 ;
			c2[2].y = y1-1 ;
			//右下 
			c2[3].x = x1+1 ;
			c2[3].y = y1-1 ;   
			for(int i=0;i<4;i++)
			{
				for(int j=0;j<n;j++)
				{
					if(c2[i].x==cre[j].x&&c2[i].y==cre[j].y)
					{
						score++ ;
						break ;
					}
				}
			}
			ans[score]++ ;
		}
	}
	for(int i=0;i<5;i++)
		printf("%d\n",ans[i]) ; 
	return 0 ;
}
wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw==

 

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值