赞
踩
一段时间没写代码了,今天试水一道直接寄了
- #include <bits/stdc++.h>
- using namespace std;
- typedef long long ll;
- ll n, m, h, w;
- ll a[1010][1010];
- int main()
- {
- cin >> n >> m;
- for (int i = 1; i <= n; i++)
- {
- for (int j = 1; j <= m; j++)
- {
- cin >> a[i][j];
- }
- }
- cin >> h >> w;
- ll sign = 0;
- for (int i = 1; i <= n; i++)
- {
- for (int j = 1; j <= m; j++)
- {
- if ((i + h - 1 <= n) && (j + w - 1 <= m)) // 添加边界条件判断
- {
- if ((a[i][j] == a[i + h - 1][j]) && (a[i][j] == a[i][j + w - 1]) && (a[i][j] == a[i + h - 1][j + w - 1]))
- {
- sign++;
- }
- }
- }
- }
- if (sign > 0)
- {
- cout << "YES" << endl;
- }
- else
- {
- cout << "NO" << endl;
- }
- return 0;
- }

第一个问题:范围问题 因为a[i + h - 1][j]和a[i][j + w - 1],所以数组范围不再是a[1010][1010]
第二个问题:扩大范围后,又忘了数组越界这回事了,毕竟数组越界的0也是可能符合题意的数据
总结:还是得天天练习,不然就寄了
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。