现在有一个城市销售经理,需要从公司出发,去拜访市内的商家,已知他的位置以及商家的位置,但是由于城市道路交通的原因,他只能在左右中选择一个方向,在上下中选择一个方向,现在问他有多少种方案到达商家地址。给定一个地图map及它的长宽n和m,其中1代表经理位置,2代表商家位置,-1代表不能经过的地区,0代表可以经过的地区,请返回方案数,保证一定存在合法路径。保证矩阵的长宽都小于等于10。
include "stdafx.h"
#include<iostream>
#include<vector>
#include<algorithm>
#include<iomanip>
using namespace std;
class Visit {
public:
int countPath(vector<vector<int> > map, int n, int m) {
int count=0;
int compX, compY, sellerX,sellerY;
for (int i = 0;i < map.size();i++)
{
for (int j = 0;j < map[0].size();j++)
{
if (map[i][j] == 1)
{
compX = i; compY = j;
// cout << "i:" << i << endl;
// cout << "j:" << j << endl;
}
if (map[i][j] == 2)
{
sellerX = i, sellerY = j;
// cout << "i:" << i << endl;
// cout << "j:" << j << endl;
}
}
}
int minX = min(sellerX,compX);
int maxX = max(sellerX, compX);
int minY = min(sellerY, compY);
int maxY = max(sellerY, compY);
vector<vector<int> > mapp;
for (int i = minX;i <= maxX;i++)
{
vector<int> vec;
for (int j = minY;j <= maxY;j++)
{
vec.push_back(map[i][j]);
}
mapp.push_back(vec);
}
if (mapp[0][0] == 1)
{
return getPathLR(mapp);
}else if(mapp[mapp.size()-1][0] == 1)
{
return getPathHR(mapp);
}
else if (mapp[0][mapp[0].size()-1] == 1)
{
return getPathLL(mapp);
}
else
{
return getPathHL(mapp);
}
}
int getPathLR(vector<vector<int> > map) {
// if (map[0][0] != 1) return 0;
if (map.size() == 1)
{
int num = 0;
for (int i = 0;i < map[0].size();i++)
{
if (map[0][i] == -1)
{
num = 0;
break;
}
if (map[0][i] == 2)
{
num = 1;
break;
}
}
return num;
}
if (map[0].size() == 1)
{
int num = 0;
for (int i = 0;i < map.size();i++)
{
if (map[i][0] == -1)
{
num = 0;
break;
}
if (map[i][0] == 2)
{
num = 1;
break;
}
}
return num;
}
return getPathLR(deleteRowLR( map) )+ getPathLR(deleteColLR(map));
}
vector<vector<int> > deleteRowLR(vector<vector<int> > map)
{
map.erase(map.begin());
return map;
}
vector<vector<int> > deleteColLR(vector<vector<int> > map)
{
for (int i = 0;i < map.size();i++)
{
map[i].erase(map[i].begin());
}
return map;
}
int getPathHR(vector<vector<int> > map) {
// if (map[map.size()-1][0] != 1) return 0;
if (map.size() == 1)
{
int num = 0;
for (int i = 0;i < map[0].size();i++)
{
if (map[0][i] == -1)
{
num = 0;
break;
}
if (map[0][i] == 2)
{
num = 1;
break;
}
}
return num;
}
if (map[0].size() == 1)
{
int num = 0;
for (int i = map.size()-1;i >=0;i--)
{
if (map[i][0] == -1)
{
num = 0;
break;
}
if (map[i][0] == 2)
{
num = 1;
break;
}
}
return num;
}
return getPathHR(deleteRowHR(map)) + getPathHR(deleteColHR(map));
}
vector<vector<int> > deleteRowHR(vector<vector<int> > map)
{
map.erase(map.end()-1);
return map;
}
vector<vector<int> > deleteColHR(vector<vector<int> > map)
{
for (int i = 0;i < map.size();i++)
{
map[i].erase(map[i].begin());
}
return map;
}
int getPathLL(vector<vector<int> > map) {
// if (map[0][map[0].size() - 1] != 1) return 0;
int count = 0;
if (map.size() == 1)
{
int num = 0;
for (int i = map[0].size()-1;i >=0;i--)
{
if (map[0][i] == -1)
{
num = 0;
break;
}
if (map[0][i] == 2)
{
num = 1;
break;
}
}
return num;
}
if (map[0].size() == 1)
{
int num = 0;
for (int i = 0;i < map.size();i++)
{
if (map[i][0] == -1)
{
num = 0;
break;
}
if (map[i][0] == 2)
{
num = 1;
break;
}
}
return num;
}
return getPathLL(deleteRowLL(map)) + getPathLL(deleteColLL(map));
}
vector<vector<int> > deleteRowLL(vector<vector<int> > map)
{
map.erase(map.begin());
return map;
}
vector<vector<int> > deleteColLL(vector<vector<int> > map)
{
for (int i = 0;i < map.size();i++)
{
map[i].erase((map[i].end()-1));
}
return map;
}
int getPathHL(vector<vector<int> > map) {
// if (map[map.size()-1][map[0].size() - 1] != 1) return 0;
if (map.size() == 1)
{
int num = 0;
for (int i = map[0].size()-1;i >=0;i--)
{
if (map[0][i] == -1)
{
num = 0;
break;
}
if (map[0][i] == 2)
{
num = 1;
break;
}
}
return num;
}
if (map[0].size() == 1)
{
int num = 0;
for (int i = map.size()-1;i >=0;i--)
{
if (map[i][0] == -1)
{
num = 0;
break;
}
if (map[i][0] == 2)
{
cout << "执行了" << endl;
num = 1;
break;
}
}
return num;
}
return getPathHL(deleteRowHL(map)) + getPathHL(deleteColHL(map));
}
vector<vector<int> > deleteRowHL(vector<vector<int> > map)
{
map.erase(map.end()-1);
return map;
}
vector<vector<int> > deleteColHL(vector<vector<int> > map)
{
for (int i = 0;i < map.size();i++)
{
map[i].erase((map[i].end() - 1));
}
return map;
}
};
int main()
{
vector<vector<int> > map;
vector<int> vec1 = { 0,1,0 };
vector<int> vec2 = { 2,0,0 };
map.push_back(vec1);
map.push_back(vec2);
Visit v;
cout << v.countPath(map, 2, 3) << endl;;
return 0;
}
现在有一个城市销售经理,需要从公司出发,去拜访市内的商家,已知他的位置以及商家的位置,但是由于城市道路交通的原因,他只能在左右中选择一个方向,在上下中选择一个方向,现在问他有多少种方案到达商家地址。给定一个地图map及它的长宽n和m,其中1代表经理位置,2代表商家位置,-1代表不能经过的地区,0代表可以经过的地区,请返回方案数,保证一定存在合法路径。保证矩阵的长宽都小于等于10。的更多相关文章
- 对于一个字符串,请设计一个高效算法,找到第一次重复出现的字符。 给定一个字符串(不一定全为字母)A及它的长度n。请返回第一个重复出现的字符。保证字符串中有重复字符,字符串的长度小于等于500。
// 第一种方法 // ConsoleApplication10.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include < ...
- 转:已知2个整形数据a,b.不使用if,?:以及其他任何条件判断的语法,找出a跟b中数据的大者。
答案: int max(int a,int b){return (a+b+abs(a-b))/2;} 类似的 请定义一个宏,比较两个数a.b的大小,不能使用大于.小于.if语句 答案: #define ...
- Linux中的两个经典宏定义:获取结构体成员地址,根据成员地址获得结构体地址;Linux中双向链表的经典实现。
倘若你查看过Linux Kernel的源码,那么你对 offsetof 和 container_of 这两个宏应该不陌生.这两个宏最初是极客写出的,后来在Linux内核中被推广使用. 1. offse ...
- WCF技术剖析之十三:序列化过程中的已知类型(Known Type)
原文:WCF技术剖析之十三:序列化过程中的已知类型(Known Type) [爱心链接:拯救一个25岁身患急性白血病的女孩[内有苏州电视台经济频道<天天山海经>为此录制的节目视频(苏州话) ...
- 【杨氏矩阵+勾长公式】POJ 2279 Mr. Young's Picture Permutations
Description Mr. Young wishes to take a picture of his class. The students will stand in rows with ea ...
- C# 序列化过程中的已知类型(Known Type)
WCF下的序列化与反序列化解决的是数据在两种状态之间的相互转化:托管类型对象和XML.由于类型定义了对象的数据结构,所以无论对于序列化还是反序列化,都必须事先确定对象的类型.如果被序列化对象或者被反序 ...
- 【React】开发一个城市选择控件
想到做这个,是因为无意中在github上看到了这一个仓库https://github.com/lunlunshiwo/ChooseCity,做的就是一个城市选择控件,是用vue写的,说的是阿里的一道题 ...
- Shell 从日志文件中选择时间段内的日志输出到另一个文件
Shell 从日志文件中选择时间段内的日志输出到另一个文件 情况是这样的,某系统的日志全部写在一个日志文件内,所以这个文件非常大,非常长,每次查阅的时候非常的不方便.所以,相关人员希望能够查询某个时间 ...
- 算法战斗:给定一个号码与通配符问号W,问号代表一个随机数字。 给定的整数,得到X,和W它具有相同的长度。 问:多少整数协议W的形式和的比率X大?
如果说: 给定一个号码与通配符问号W,问号代表一个随机数字. 给定的整数,得到X,和W它具有相同的长度. 问:多少整数协议W的形式和的比率X大? 进格公式 数据的多组,两排各数据的,W,第二行是X.它 ...
随机推荐
- 【BZOJ4300】绝世好题(二进制,DP)
题意: n<=100000,ai<=2*10^9 思路:按二进制逐位考虑,只要有至少1位取and后为1就可以接下去 设dp[i]为第i位取and之后为1的最长的序列长度,意会一下 #inc ...
- 代码怎样重构<1>
原文发布时间为:2011-05-24 -- 来源于本人的百度文章 [由搬家工具导入]
- 【jetty】jetty服务器的使用
1.下载jetty服务器: http://www.eclipse.org/jetty/previousversions.html 2.下载后解压:
- luogu 2463 [SDOI2008]Sandy的卡片 kmp || 后缀数组 n个串的最长公共子串
题目链接 Description 给出\(n\)个序列.找出这\(n\)个序列的最长相同子串. 在这里,相同定义为:两个子串长度相同且一个串的全部元素加上一个数就会变成另一个串. 思路 参考:hzwe ...
- 我的arduino theme文件
#FUNCTIONS COLOR #D35400 - ORANGE KEYWORD1 #FUNCTIONS COLOR #D3540 ...
- Selenium2+python自动化(学习笔记3)
1.加载firefox配置 参考代码: # coding=utf-8from selenium import webdriver# 配置文件地址,打开Firefox点右上角设置--帮助--故障排除信息 ...
- CSS定位与布局:浮动
浮动的特点 浮动(float)属性提出的作用是实现文字的环绕效果,一个元素浮动后,会脱离普通流.主要的特点如下: 浮动的元素会向左或者向右移动直到它的外边缘接触容器框(containing blo ...
- Ruby Time And DateTime之Time in Core
今天遇到一个问题,就是在Ruby中对于Time和DateTime的使用,不是很明了,现在研究一下: 先说Time: 在Ruby2.0中关于Time有两处定义一个是在Core中,http://www.r ...
- 如何让自己的程序支持iPhone5–RetinaImages
我们知道如果想让程序的启动图像能够适应iPhone5(640X1136),那么我们需要把启动的图像命名以“-568h@2x”结尾的图片,那 么是不是程序中用到的所有图片都可以用这样的方式来命名,以适合 ...
- (转)python装饰器二
Python装饰器进阶之二 保存被装饰方法的元数据 什么是方法的元数据 举个栗子 def hello(): print('Hello, World.') print(dir(hello)) 结果如下: ...