腾讯的题目,一条简单的搜索题目。适合刚開始学习的人练习代码能力。或者是高手歇息脑子的题。呵呵,不须要动脑了,仅仅动手打代码就过了。
只是腾讯这故事有点坏啊。给人透露了两个信息:
1 腾讯不拘一格降人才
2 进入腾讯就能够屌丝逆袭了
腾讯是不是还想说腾讯的mm特别多?
呵呵。出题不忘给自己宣传一下。
#include#include const int MAX_NM = 20;int N, M;int matrix[MAX_NM][MAX_NM];inline int abs(int a) { return a < 0 ?
-a : a; } inline int getCharm(int i, int j) { int charmVal = 0; if (i>0) { if ((matrix[i-1][j]>>31) ^ (matrix[i][j]>>31)) charmVal += abs(matrix[i-1][j]); else charmVal -= abs(matrix[i-1][j]); } if (i+1 < N) { if ((matrix[i+1][j]>>31) ^ (matrix[i][j]>>31)) charmVal += abs(matrix[i+1][j]); else charmVal -= abs(matrix[i+1][j]); } if (j>0) { if ((matrix[i][j-1]>>31) ^ (matrix[i][j]>>31)) charmVal += abs(matrix[i][j-1]); else charmVal -= abs(matrix[i][j-1]); } if (j+1 < M) { if ((matrix[i][j+1]>>31) ^ (matrix[i][j]>>31)) charmVal += abs(matrix[i][j+1]); else charmVal -= abs(matrix[i][j+1]); } return charmVal; } int main() { while (scanf("%d %d", &N, &M) && N) { for (int i = 0; i < N; i++) { for (int j = 0; j < M; j++) { scanf("%d", &matrix[i][j]); } } int u, v, maxCharm = INT_MIN; for (int i = 0; i < N; i++) { for (int j = 0; j < M; j++) { int charmVal = getCharm(i, j); if (maxCharm < charmVal) { maxCharm = charmVal; u = i, v = j; } } } printf("%d %d %d\n", u+1, v+1, maxCharm); } return 0; }