盛大游戏游戏服务端C++笔试第二题岛屿个数题请教

在本机能成功运行,但为啥一直提交错误呢,下面代码有啥错误啊,请大佬指教
#include <iostream>
#include <vector>
using namespace std;

int l[4] = { -1, 0, 1, 0 };
int r[4] = { 0, -1, 0, 1 };

void dfs(vector<vector<int>> &v, const int a, const int b) {
	v[a][b] = 0;
	for (int k = 0; k < 4; ++k) {
		int i = l[k] + a, j = r[k] + b;
		if (i >= 0 && i < v.size() && j >= 0 && j < v[0].size()) {
			if (v[i][j] == 1)
				dfs(v, i, j);
		}
	}
}

int main() {
	int n, m;
	cin >> n >> m;
	vector<vector<int>> v(n, vector<int>(m));
	int val;
	for (int i = 0; i < n; ++i)
		for (int j = 0; j < m; ++j)
			cin >> v[i][j];
	int count = 0;
	for (int i = 0; i < n; ++i) {
		for (int j = 0; j < m; ++j)
			if (v[i][j] == 1) {
				dfs(v, i, j);
				++count;
			}
	}
	cout << count << endl;
	return 0;
}

全部评论
输入的是11110而不是1 1 1 1 0
点赞
送花
回复
分享
发布于 2017-09-10 21:32
输入有问题,你这个输入只用输入n行然后拆数
点赞
送花
回复
分享
发布于 2017-09-10 21:32
秋招专场
校招火热招聘中
官网直投
我和你的差不多,本地可以,提交就是不通过
点赞
送花
回复
分享
发布于 2017-09-10 21:28
如果知道是哪里的原因,也告诉我一声啊
点赞
送花
回复
分享
发布于 2017-09-10 21:29
同本地可以。。提交不行
点赞
送花
回复
分享
发布于 2017-09-10 21:32
我的一直90%,调了50分钟一直90%。。。块疯了都。。。 #include<iostream> #include<vector> using namespace std; void spread(vector<vector<int> > & island , int y , int x) { // cout<<x<<" "<<y; island[y][x] = 2; if(y-1>=0 && 1 == island[y-1][x]) spread(island, y-1 , x); if(y+1<island.size() && 1 == island[y+1][x]) spread(island, y+1 , x); if(x-1>=0 && 1 == island[y][x-1]) spread(island, y , x-1); if(x+1<island[0].size() && 1 == island[y][x+1]) spread(island, y , x+1); } int main() { int n , m; cin>>n>>m; vector<vector<int> > island(n, vector<int>(m)); char temp; for(int i = 0 ; i < n ; i++) { for(int j = 0 ; j < m ; j++) { cin>>temp; if('0' == temp) island[i][j] = 0; else if('1' == temp) island[i][j] = 1; else{ cout<<0<<endl; return 0; } } } int result = 0; for(int i = 0 ; i < n ; i++) { for(int j = 0 ; j < m ; j++) { if(1 != island[i][j])continue; result++; spread(island,i,j); } } cout<<result<<endl; return 0; }
点赞
送花
回复
分享
发布于 2017-09-10 21:33
你的那个是因为它给的数字是连续的,没有空格间隔开来,所以没有读取好
点赞
送花
回复
分享
发布于 2017-09-10 21:35
是char
点赞
送花
回复
分享
发布于 2017-09-10 22:55
字符1 0
点赞
送花
回复
分享
发布于 2017-09-10 22:56
666
点赞
送花
回复
分享
发布于 2017-09-10 22:59
每行都应该是字符串读进去就对了
点赞
送花
回复
分享
发布于 2017-09-10 23:34

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务