当前位置: 首页 > news >正文

网站建设开发费入什么科目营销渠道的选择和营销网络的建设

网站建设开发费入什么科目,营销渠道的选择和营销网络的建设,普通人学python有意义吗,中山企业网站多少钱①这道题可以直接申请一个临时数组,然后遍历字符串,是空格则加入20%,最后再把临时数组转化为字符串。 怎么把一个数组转化为字符串? 如数组arry[], string newstr new string(arry,0,arry.size()-1); return newstr; 而且临时数…


①这道题可以直接申请一个临时数组,然后遍历字符串,是空格则加入20%,最后再把临时数组转化为字符串。
怎么把一个数组转化为字符串?
如数组arry[],
string newstr = new string(arry,0,arry.size()-1);
return newstr;
而且临时数组的空间要申请大一些。
public String replaceSpace(String s) {
        int length = s.length();
        char[] array = new char[length * 3];
        int index = 0;
        for (int i = 0; i < length; i++) {
            char c = s.charAt(i);
            if (c == ' ') {
                array[index++] = '%';
                array[index++] = '2';
                array[index++] = '0';
            } else {
                array[index++] = c;
            }
        }
        String newStr = new String(array, 0, index);
        return newStr;
    }

②或者用栈,只是出栈后结果是需要来个翻转吗?有点不大会。


③不过上面的这些方法都需要时间复杂度O(n),并且空间复杂度O(n)。
接下来有个时间复杂度O(n),但是空间复杂度O(1)的做法,要是学会了也不难,接下来说说这种解法。
这个解法就不需要申请新的空间。
第一步,首先扩充数组到每个空格替换成"%20"之后的大小。
比如这道题,每个空格要变成20%,即一个空格变成了3个空格,所以每个空格处要添加2个空格,即先统计字符串中有多少个空格,然后+多少个空格*2。怎么添加字符串长度?
//s.resize(n); resize将string类中有效字符改变到n个。
第二步,从后向前替换空格,也就是双指针法,过程如下:
i指向新长度的末尾,j指向旧长度的末尾。
然后i,j往前,如果s[j]不是空格则把s[j]赋给s[i]; 如果s[j]是空格,则s[i]赋为0, s[i-1]赋为2, s[i-2]赋为%,并且i往前移三格。然后继续i,j一起往前移继续如此轮下去。


④有同学问了,为什么要从后向前填充,从前向后填充不行么?
从前向后填充就是O(n^2)的算法了,因为每次添加元素都要将添加元素之后的所有元素向后移动。

⑤其实很多数组填充类的问题,都可以先预先给数组扩容带填充后的大小,然后在从后向前进行操作。
这么做有两个好处:
不用申请新数组。
从后向前填充元素,避免了从前向后填充元素时,每次添加元素都要将添加元素之后的所有元素向后移动的问题。


当i=j时,即说明扩充的空格都用完了,说明前面已经没有空格要变成20%了,所以就可以结束了,所以循环结束条件就是j<i,而不是j<=i。
 

class Solution {
public:
    string replaceSpace(string s) {
        int count = 0; // 统计空格的个数
        int sOldSize = s.size();
        for (int i = 0; i < s.size(); i++) {
            if (s[i] == ' ') {
                count++;
            }
        }
        // 扩充字符串s的大小,也就是每个空格替换成"%20"之后的大小
        s.resize(s.size() + count * 2);
        int sNewSize = s.size();
        // 从后先前将空格替换为"%20"
        for (int i = sNewSize - 1, j = sOldSize - 1; j < i; i--, j--) {
            if (s[j] != ' ') {
                s[i] = s[j];
            } else {
                s[i] = '0';
                s[i - 1] = '2';
                s[i - 2] = '%';
                i -= 2;
            }
        }
        return s;
    }
};
 


 

http://www.yayakq.cn/news/158164/

相关文章:

  • 用上海注册的公司建的网站北京网站托管
  • 电子商务网站建设的风险分析百度指数官网查询入口
  • 朝阳seo网站建设html 医药网站模板
  • 33岁改行做网站建设想开网店不知道怎么开
  • 南宁网站快速优浙江网站建设品牌升级
  • 完成网站的建设工作总结沈阳网络推广
  • 餐饮vi设计网站苏州园区房价
  • 沧浪网站建设怎样做水族馆网站
  • 制作企业网站用什么软件多个网站集成在一个页面
  • 360 的网站链接怎么做登录企业邮箱入口
  • 莆田网站建设方案服务八戒商标注册网
  • 网站规划与站点的建立实训报告网站建设的审批部门是
  • 默认网站建立怎么做网页设计的页面
  • 网站配色与布局 教材最常用的网站推广方式
  • 字体样式 网站layerslider wordpress
  • wordpress免费自定义模板装修教程关键词优化排名要多少钱
  • 南京建设个人网站营销思路和创新点
  • 高端大气网站知彼网络网站建设
  • 商业型网站78建筑网站
  • 网站 建设平台分析报告设计服务商
  • 设计公司网站公司详情常用搜索网站
  • 郑州网站专业建设qqwordpress 登录评论
  • 知乎建站平台自己买服务器可以搭建网站吗
  • 贵州建设厅考试网站准考证下载网站建设业务员沟通需求
  • 北京网站设计培训班网站建设与维护大作业
  • paypal外贸门户网站热狗网站关键词优化
  • 选服务好的网站建设装修公司电话号码大全
  • 网上的网站模板怎么用国内最新保理公司排名
  • 江门做网站那家公司好工程公司绩效考核
  • 全国目前最火的加盟店seo金融术语