zoukankan      html  css  js  c++  java
  • 九度 二维数组中的查找

    /*
     * c.cpp
     *
     *  Created on: 2013-10-7
     *      Author: wangzhu
     */
    
    #include<cstdio>
    #include<iostream>
    using namespace std;
    #define NMAX 1000010
    int arr[NMAX];
    /**
     * 只需要从左下角或右上角开始查找,即可。
     * 当是从右上角开始查找时,
     * 左上角(row = 0,column = columns - 1),
     * 1)若查找的值key大于当前的值arr[i],则说明key在此行以下,故有row++;
     * 2)若查找的值key小于当前的值arr[i],则说明key在此列的左边,故有column--;
     * 3)若相等,则返回true
     * 4)判断条件:row<rows && column >=0,若满足,继续1),若不满足,则直接返回false
     */
    bool query(int rows, int columns, int key) {
        bool flag = false;
        int column = columns - 1;
        int row = 0;
        while (row < rows && column >= 0) {
            int temp = arr[row * columns + column];
            if (temp == key) {
                flag = true;
                return flag;
            } else if (temp > key) {
                column--;
            } else {
                row++;
            }
        }
        return flag;
    }
    /**
     * 当是从左下角开始查找时,
     * 左上角(row = rows - 1,column = 0),
     * 1)若查找的值key小于当前的值arr[i],则说明key在此行以下,故有row--;
     * 2)若查找的值key大于当前的值arr[i],则说明key在此列的左边,故有column++;
     * 3)若相等,则返回true
     * 4)判断条件:row >= 0 && column < columns,若满足,继续1),若不满足,则直接返回false
     */
    bool query1(int rows, int columns, int key) {
        bool flag = false;
        int column = 0;
        int row = rows - 1;
        int temp = -1;
        while (row >= 0 && column < columns) {
            temp = arr[row * columns + column];
            if (temp == key) {
                flag = true;
                return flag;
            } else if (temp > key) {
                row--;
            } else {
                column++;
            }
        }
        return false;
    }
    int main() {
        freopen("data.in", "r", stdin);
        int n, m, t, len;
        bool flag;
        while (~scanf("%d%d%d", &n, &m,&t)) {
            len = n * m;
            for (int i = 0; i < len; i++) {
                scanf("%d", arr + i);
            }
            flag = query1(n, m, t);
            if (flag) {
                printf("Yes
    ");
            } else {
                printf("No
    ");
            }
        }
        return 0;
    }
  • 相关阅读:
    免费云盘,为什么不用?
    把握linux内核设计思想系列
    volley基本使用方法
    金朝阳——软件測试试题11道题目分享
    可编辑ztree节点的增删改功能图标控制---已解决
    POJ 3370 Halloween treats 鸽巢原理 解题
    Axure RP一个专业的高速原型设计工具
    Linux内核剖析 之 进程简单介绍
    [iOS]怎样在iOS开发中切换显示语言实现国际化
    scp and tar
  • 原文地址:https://www.cnblogs.com/xiaoxian1369/p/3355601.html
Copyright © 2011-2022 走看看