字符迷阵

50 篇文章 1 订阅
#include<vector>
#include<iostream>
#include<string>
using namespace std;
vector<int> ves;
int M, N;
char **map;
int times = 0;
void find(int x, int y, int index, int length, string& X, int dir)
{
	if (map[x][y] != X[index - 1])
		return;
	if (index == length)
	{
		times++;
		return;
	}

	if (dir == 1)
	{
		find(x, y + 1, index + 1, length, X, 1);
	}
	else if (dir == 2)
	{
		find(x + 1, y, index + 1, length, X, 2);
	}
	else
	{
		find(x + 1, y + 1, index + 1, length, X, 3);
	}

}

int main()
{

	int T;
	cin >> T;
	while (T--)
	{
		cin >> M >> N;
		cin.ignore();
		map = new char*[M + 2];
		for (int i = 0; i < M + 2; i++)
		{
			map[i] = new char[N + 2];
			for (int j = 0; j < N + 2; j++)
				map[i][j] = ' ';
		}

		for (int i = 1; i <= M; i++)
		{

			string ss;

			getline(cin, ss);
			//cout << ss << endl;
			if (ss.length() >= N)
			{
				for (int j = 1; j <= N; j++)
					map[i][j] = ss[j - 1];
			}
			else
				cout << ss.length() << " Error" << endl;
		}

		string X;
		getline(cin, X);
		int size = X.length();
		times = 0;

		for (int i = 1; i <= M; i++)
			for (int j = 1; j <= N; j++)
			{
				if (map[i][j] == X[0])
				{
					find(i, j + 1, 2, size, X, 1);
					find(i + 1, j, 2, size, X, 2);
					find(i + 1, j + 1, 2, size, X, 3);
				}
			}
		cout << times << endl;
		times = 0;
		for (int i = 0; i < M + 2; i++)
		{
			delete[] map[i];
		}
		delete[] map;
		map = nullptr;

	}
	//cin.get();
	return 0;
}

== 注意 == cin >>使用后 ,末尾的换行符并未清除,导致getline(cin, string)第一次读到的是换行,所以要加一个cin.ignore();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值
>