牛客网-编程练习001

题目描述

在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。

解法一:

运行时间;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';
            }
        }
    }
};

猜你喜欢

转载自blog.csdn.net/heda3/article/details/81037971
今日推荐