标签:
4 4 1 2 8 9 2 4 9 12 4 7 10 13 6 8 11 15 3 7 8 14
3 2 1 3 NO
解题思路:虽然用二分可以处理,但是用O(n+m)的复杂度过。由于矩阵是有特殊关系的。从每行左向右递增,每列从上向下递增。于是从第一行最右端起,如果元素大于要找的值,则往左移动,因为该列下边的值都比该元素,如果该元素小于要找的值,则向下移动,继续按照上边的方法判断,如果要找的位置不在矩阵内了,说明没有元素在矩阵中,否则输出位置即可。
#include<bits/stdc++.h> using namespace std; int a[2000][2000]; int main(){ int n,m,q,aim,x,y; while(scanf("%d%d",&n,&m)!=EOF){ for(int i=0;i<n;i++){ for(int j=0;j<m;j++) scanf("%d",&a[i][j]); } scanf("%d",&q); for(int j=0;j<q;j++){ scanf("%d",&aim); int y=m-1,x=0; bool flag=0; while(true){ if(a[x][y]>aim){ y--; if(y<0){ flag=1; break; } }else if(a[x][y]<aim){ x++; if(x>=n){ flag=1; break; } }else{ break;} } if(flag){ printf("NO\n"); }else{ printf("%d %d\n",x+1,y+1); } } } return 0; }
标签:
原文地址:http://www.cnblogs.com/chengsheng/p/4479038.html