人工智能

博客给出一段算法代码,定义了二维数组和方向数组,通过函数遍历二维数组元素,根据条件更新计数和数组元素值,最终输出特定计算结果,体现了算法在解决问题中的应用。

#include <bits/stdc++.h>
using namespace std;
int a[1100][1100],n,c;
int num[1100][1100];
int d[8][2]= {{-1,0},{0,1},{1,0},{0,-1},{-1,-1},{-1,1},{1,1},{1,-1}};
void fun(int x,int y,int ox,int oy) {
for(int i=0; i<8; i++) {
while(x+d[i][0]>=1&&x+d[i][0]<=n&&y+d[i][1]>=1&&y+d[i][1]<=n&&a[x+d[i][0]][y+d[i][1]]==0) {
num[x+d[i][0]][y+d[i][1]]++;
if(num[x+d[i][0]][y+d[i][1]]==1) {
c++;
}
x=x+d[i][0];
y=y+d[i][1];
}
x=ox;
y=oy;
if(a[ox][oy]==1&&i=
=3) {
break;
}
}
}
int main() {
int i,j;
cin>>n;
for(i=1; i<=n; i++) {
for(j=1; j<=n; j++) {
cin>>a[i][j];
}
}
for(i=1; i<=n; i++) {
for(j=1; j<=n; j++) {
if(a[i][j]==1||a[i][j]==2) {
c++;
num[i][j]++;
fun(i,j,i,j);
}
}
}
cout<<n*n-c<<endl;
return 0;
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值