题目描述
在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。
解法一:
运行时间;10ms 1500k
class Solution
{public:
bool Find(int target, vector<vector<int> > array) {
for(int i=0;i<array.size();i++)
{
int low=0;
int high=array[i].size()-1;
while(low<=high)
{//实现每列遍历 二分法
int mid=(low+high)/2;
if(target>array[i][mid])
low=mid+1;
else if(target<array[i][mid])
high=mid-1;
else
return true;
}
}
return false;
}
};
解法二
运行时间:12ms 1512k
class
Solution {
public
:
bool
Find(
int
target, vector<vector<
int
> > array) {
// array是二维数组,这里没做判空操作
int
rows = array.size();
int
cols = array[0].size();
int
i=rows-1,j=0;
//左下角元素坐标
while
(i>=0 && j<cols){
//使其不超出数组范围
if
(target<array[i][j])
i--;
//查找的元素较小,往上找
else
if
(target>array[i][j])
j++;
//查找元素较大,往右找
else
return
true
;
//找到
}
return
false
;
}
};
class Solution {
public:
void replaceSpace(char *str,int length) {
int flag1=0,flag2=0;
for(int i=0;i<length-1;i++)
{
if(str[i]==' ')
flag1++;
}
for(int i=0;i<length-1+flag1*2;i++)
{
if(str[i]==' ')
{
flag2++;
str[i]='%';
for(int j=0;j<length-1+(flag2-1)*2-i;j++)
{
str[length+1-j]=str[length-1-j];
}
str[i+1]='2';
str[i+2]='0';
}
}
}
};
请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
class Solution {
public:
void replaceSpace(char *str,int length) {
int flag1=0,flag2=0;
for(int i=0;i<length-1;i++)
{
if(str[i]==' ')
flag1++;
}
for(int i=0;i<length-1+flag1*2;i++)
{
if(str[i]==' ')
{
flag2++;
str[i]='%';
for(int j=0;j<length-1+(flag2-1)*2-i;j++)
{
str[length+1-j]=str[length-1-j];
}
str[i+1]='2';
str[i+2]='0';
}
}
}
};
答案错误:您提交的程序没有通过所有的测试用例
case通过率为87.50%
测试用例:
" "
对应输出应该为:
"%20%20%20"
你的输出为:
"%20%2%220"
修改成功:
用时5ms 480k
class Solution {
public:
void replaceSpace(char *str,int length) {
int flag1=0,flag2=0;
for(int i=0;i<length-1;i++)
{
if(str[i]==' ')
flag1++;
}
for(int i=0;i<length-1+flag1*2;i++)
{
if(str[i]==' ')
{
flag2++;
str[i]='%';
for(int j=0;j<length-1+(flag2-1)*2-i;j++)
{
str[length+1+(flag2-1)*2-j]=str[length-1+(flag2-1)*2-j];//从找到的第一个空格开始往右移动数据 也就是涉及到了重复移动
}
str[i+1]='2';
str[i+2]='0';
}
}
}
};
解法2:
4ms 604k
class Solution {
public:
void replaceSpace(char *str,int length)
{
int count=0;
for(int i=0;i<length;i++)
{
if(str[i]==' ')
count++;
}
for(int i=length-1;i>=0;i--)
{
if(str[i]!=' ')
{
str[i+2*count]=str[i];
}
else
{
count--;
str[i+2*count]='%';
str[i+2*count+1]='2';
str[i+2*count+2]='0';
}
}
}
};