大厂面试真题详解分割字符串

简介: 大厂面试真题详解:分割字符串

给一个字符串,你可以选择在一个字符或两个相邻字符之后拆分字符串,使字符串由仅一个字符或两个字符组成,输出所有可能的结果在线评测地址:领扣题库官网

样例1

输入: "123"输出: [["1","2","3"],["12","3"],["1","23"]]

样例2

输入: "12345"输出: [["1","23","45"],["12","3","45"],["12","34","5"],["1","2","3","45"],["1","2","34","5"],["1","23","4","5"],["12","3","4","5"],["1","2","3","4","5"]]算法:DFS

由于本题可以选择在一个字符或两个相邻字符之后拆分字符串,且最后需输出所有可能的组合,即每次都需要把整个字符串按照特定要求切分完毕,可以想到利用递归dfs来完成;算法步骤对字符串进行深度优先搜索,当前位置达到字符串末尾作为边界。搜索时有两种情况:

切割当前的1个字符:将这1个字符单独作为字符串存入列表当前位置步进1切割当前的连续2个字符(需满足当前位置不是字符串末尾):将连续2个字符保存为字符串存入列表当前位置步进2复杂度分析时间复杂度:O(2^n), n为字符串长度除了字符串最后一位,其他位置都有两种切割方式空间复杂度:O(2^n^2),n为字符串长度存储所有情况需要所有切分方式*n 的空间public class Solution { /* * @param : a string to be split * @return: all possible split string array */ public List> splitString(String s) { List> result = new ArrayList(); dfs(s, 0, new ArrayList(), result); return result; } private void dfs(String s, int index, List current, List> result) { if (index == s.length()) { result.add(new ArrayList(current)); return; } // 分割1个字符 current.add(String.valueOf(s.charAt(index))); dfs(s, index 1, current, result); current.remove(current.size() - 1); // 分割2个字符 if (index 原文>>https://developer.aliyun.com/article/777455?spm=a2c6h.12873581.0.0.23ee56813TTmTB&groupCode=ai

大厂面试真题详解分割字符串

2020年Web前端面试题及答案汇总

今天小编要跟大家分享的文章是关于2020年Web前端面试题及答案汇总。正准备参加Web前端面试的小伙伴们来和小编一起看一看吧,希望本篇文章能够对大家有所帮助。





一、MySQL数据库


1.MySQL中varchar与char的区别以及varchar(50)中的50代表的涵义?


答案:


Varchar是变长字符串,最多存储的大小是65535字节,查询速度相对较慢;Char
是定常字符串,最多存储的大小是255字节,查询速度相对较快;


varchar(50)表示:Mysql4.0表示存放50个字节,5.0存放50个字符。


2.简述浏览器打开#显示页面,中间都经过哪些过程?


答案:


向DNS服务器获取域名对应的IP地址并返回浏览器,通过IP地址向Web服务器发请求,Web服务器从文件服务器获取网页中所需要的文件,从数据库服务器获取网页中所需要的数据,最后讲完整的网页相应给浏览器。


3.如何解决MySQL中存储中文乱码问题?


答案:


脚本文件采用UTF8编码


客户端连接数据库使用UTF8编码


服务器端创建数据库使用UTF8编码


4.Float和Double的区别是什么?


答案:


FLOAT(单精度浮点数)类型数据可以存储至多8位十进制数,并在内存中占4字节。


DOUBLE(双精度浮点数)类型数据可以存储至多18位十进制数,并在内存中占8字节。


5.把数据id等于1的名字oldboy更改为oldgirl?


答案:


updatetestsetname='oldgirl'whereid=1;


6.如何登录mysql数据?


答案:


mysql-uroot。


二、JS基础


1.continue和break有什么区别?


答案:


break和continue都是用来控制循环结构的:


break终止循环,跳出循环体执行循环后面的语句。


continue跳过本次循环,执行下一次循环。


2.i 和 i的区别?


答案:


i :先用i值后加1,


i:先加1后用i值,


计算:varn=5;求varnum=n n n n n;//37


3.JavaScript都有哪些数据类型?


答案:


原始类型:数值型/字符串型/布尔型/undefined/null


引用类型:对象


4.自调用函数是什么?用于什么地方?


答案:立即执行的函数。(function(){//函数体})();


用于创建一个局部作用域。


5.slice和splice有什么区别?


答案:


slice截取子数组,从指定的数组中,截取几个连续的元素组成一个新数组


splice允许从指定数组中,删除一部分元素,同时再添加另一部分元素


6.typeof返回的类型有哪些?


答案:


number、string、boolean、undefined、object、function


ex:


vararr=[1,2,3,4,5];


console.log(typeof(arr));//object


functionmyDemo(){


returnfunctiontest(){};


}


console.log(typeof(myDemo()));//function


7.取1~11之间的随机数(即包括1不包括11)?


答案:


Math.floor(Math.random()*10 1)


parseInt(Math.random()*10 1)


8.什么是变量声明提前?


答案:


使用var关键字声明的变量,会将声明提升到所在作用域的最前边。。


9.push、pop、shift和unshift区别?


答案:


这两组同为对数组的操作,并且会改变数组的本身的长度及内容。


不同的是push()、pop()是从数组的尾部进行增减,unshift()、shift()是从数组的头部进行增减。。


10.例举4种强制类型转换和3种隐式类型转换?


答案:


强制转换:parseInt/parseFloat/Number/toString


隐式转换:


字符串 数值数值转字符串


数值 布尔型布尔型中true转为1,false转为0


字符串 布尔型布尔型转为字符串。


11.函数声明与函数表达式的区别?


答案:


相同点:两者都可以创建函数。


不同点:函数声明可以存在函数提升(前),函数表达式不存在函数提升(前)。


//函数声明


functionmyFunction(){


functioninnerFunction(){}


}


//以下为函数表达式


varmyFunc=function(){};


myFunc(function(){


returnfunction(){};


});


12.请指出JavaScript宿主对象和原生对象的区别?


答案:


宿主对象:指JavaScript解释器提供的对象,由解释器厂家自定义并提供实现,不同的解释器提供的扩展对象存在较大的差异(DOM和BOM对象)。


原生对象:JavaScript语言本身预定义的对象,在ECMAScript标准中定义,由所有的解释器厂家来提供具体实现(Array,Date,Math,Number,String,Boolean等)。


13.js中有哪些内置函数?


答案:Object,Array,Boolean,Number,String,Function,Date,Math,RegExp,
Error,Global


14.列举出获取日期相关函数


答案:


console.log(Date.now());//返回当前日期和时间'1970/01/0100:00:00'之间的毫秒值


vardt=newDate();//获取当前时间---年月日时分秒


console.log(dt.getTime());//返回当前日期和时间'1970/01/0100:00:00'之间的毫秒值


console.log(dt.getFullYear());//年份


console.log(dt.getMonth() 1);//月份(0-11)


console.log(dt.getDate());//日期(0/1-31)


console.log(dt.getDay());//星期(0-6)


console.log(dt.getHours());//小时(0-23)


console.log(dt.getMinutes());//分钟(0-59)


console.log(dt.getMilliseconds);//返回毫秒(0-999)


console.log(dt.getSeconds());//秒(0-59)


15.Math相关函数


答案:


Math.random()-返回0~1之间的随机数


Math.abs(x)-返回数的绝对值


Math.ceil(x)-向上取整


Math.floor(x)-向下取整


Math.round()四舍五入


Math.max()和Max.min()获取一组数据中的最大值和最小值


Math.PI获取圆周率π的值Math.pow()获取一个值的多少次幂


Math.sqrt()对数值开方


Math.pow(10,2)=100;


Math.sqrt(100)=10;


16.null和undefined的区别?


答案:


undefined是访问一个未初始化的变量时返回的值,


null是访问一个尚不存在的对象时所返回的值。因此,可以把undefined看作是空的变量,而null看作是空的对象。


17.==和===有什么不同?


答案:


==抽象相等,比较时,会先进行类型转换,然后再比较值;


===严格相等,判断两个值相等同时数据类型也得相同。


18.setTimeout和setInterval的区别是什么?


答案:


二者都是用来设置定时操作的。


setTimeout:设置一个定时器,在定时器到期后执行一次函数或代码段


setInterval:设置一个定时器,以固定的时间间隔重复调用一个函数或者代码段


19.请说出以下代码执行结果


for(vari=0;i

setTimeout(function(){


console.log(i);


},0);


console.log(i);


}


答案:012333,执行过程如下


vari=0;


console.log(i);i ;


console.log(i);i ;


console.log(i);i ;


setTimeout(function(){console.log(i);


},0);s


etTimeout(function(){


console.log(i);


},0);


setTimeout(function(){


console.log(i);


},0);//输出012333


20.请说出(true flase)>2 true的执行结果


答案:false


21.当前代码块输出结果是什么?


varz=10;


functionfoo(){console.log(z);}


(function(funArg){varz=20;funArg();})(foo);


答案:10,自调用函数。


22.setTimeout(function(){},10)表示什么意思?


答案:每隔10毫秒调用一次函数。


23.程序中捕获异常的方法?


答案:


try{


}catch(e){


}finally{


}


24.以下代码执行结果?


varuname='jack'


functionchange(){


alert(uname)//?


varuname='lily'


alert(uname)//?


}


change()


答案:undefinedlily


25.如何使用npm下载express模块?


答案:npminstallexpress


26.split和join的区别?


答案:split()将字符串按照指定的字符分割成一个数组,并返回


join()将数组用指定的字符连接成一个字符串,并返回


27.看下列代码会有什么样的输出?


varfoo="11" 2-"1";


console.log(foo);


console.log(typeoffoo);


答案:111number


28.foo=foo||bar,这行代码是什么意思?为什么要这样写?


答案:这种写法称之为短路表达式


相当于:


varfoo;


if(foo){


foo=foo;


}else{


foo=bar;


}


常用于函数参数的空判断


29.用js实现随机选取10_100之间的10个数字,存入一个数组,并排序


答案:


functiongetRandom(istart,iend){


variChoice=iend-istart 1;


returnMath.floor(Math.random()*iChoice istart);


}variArray=[];


for(vari=0;i

varresult=getRandom(10,100);


iArray.push(result);


}iArray.sort();


30.如何获取javascript三个数中的最大值和最小值?


答案:Math.max(a,b,c);//最大值


Math.min(a,b,c)//最小值


31.实现冒泡排序?


vararray=[5,4,3,2,1];


vartemp=0;


for(vari=0;i

for(varj=0;j

if(array[j]>array[j 1]){


temp=array[j 1];


array[j 1]=array[j];


array[j]=temp;


}


}


三、NODEJS


1.同步和异步有何区别?


答案:


同步:指发送一个请求,需要等待返回,然后才能够发送下一个请求,有等待过程(在一个任务进行中时不能开启其他的任务)。


异步:指发送一个请求,不需要等待返回,随时可以再发送下一个请求,即不需要等待(在一个任务进行中时可以开启其他的任务)。


2.NodeJS中有哪些类型模块,文件操作用哪一个模块?


答案:


模块类型:核心模块、自定义模块、第三方模块。


文件操作:fs模块


3.对NodeJS的优点和缺点提出自己的看法?


答案:CPU密集型任务的特点是进行大量的计算,消耗CPU资源,比如计算圆周率(上千位)、对视频进行编码等,全靠CPU的运算能力
(一般用C语言,java)IO(Input/
Output)密集型任务,这类任务的特点是CPU消耗很少,大部分时间都在等待IO操作。常见的大部分任务都是IO密集型任务,比如Web应用(一般用脚本语言:python/Nodejs)。Nodejs设计思想中以事件驱动、异步、非堵塞I/O密集型为核心,他提供的大多数api都是基于事件的、异步的风格。所以非常适合处理高并发请求。此外,与Node服务器交互的客户端代码是由js语言编写的,因此客户端和服务器端都用同一种语言编写,减少了成本。


4.使用NodeJS完成登录功能(编写HTML页面和路由接口中的代码)?


答案:


HTML页面:





用户:


密码:








user.js路由


constexpress=require('express');


constpool=require('../pool.js');


varrouter=express.Router();


router.post('/login',(req,res)=>{


varobj=req.body;


var$uname=obj.uname;


if(!$uname){


res.send({code:401,msg:'unamerequired'});


return;


}


var$upwd=obj.upwd;


if(!$upwd){res.send({code:402,msg:'upwdrequired'});


return;


}


varsql='SELECT*FROMxz_userWHEREuname=?ANDupwd=?';
pool.query(sql,[$uname,$upwd],(err,result)=>{


if(err)throwerr;


if(result.length>0){


res.send({code:200,msg:'loginsuccess'});


}else{


res.send({code:301,msg:'loginerror'});


}});


});


//路由器导出


module.exports=router;


5.什么是Nodejs?


Nodejs是一个JavaScript的运行环境,是一个服务器端的“JavaScript解释器”,用于方便高效地搭建一些响应速度快、易于扩展的网络应用。它采用事件驱动、异步编程,为网络服务而设计

大厂面试真题详解分割字符串

关于JAVA分割字符串的小题目

1.分割字符串“oneworldonedream”,划界标志分别是“o”和“n”。
public class TestStr {
public static void main(String args[]){
String s = "oneworldonedream";
String sp[] = s.split("o");
for(int i=0;i<sp.length;i ){
String spp[]=sp[i].split("n");
for(int j=0;j<spp.length;j ){
if(!(spp[j]==null||spp[j].equals(""))){
System.out.println(spp[j]);
}
}
}
}
}
2.将上题的第一个“o”改为大写,并输入修改后的字符串。
public class TestStrUp {
public static void main(String args[]){
String s = "oneworldonedream";
String s1 = s.substring(0,1);
String s2 = s.substring(1);
s1 = s1.toUpperCase();
System.out.println(s1 s2);
}
}
呵呵 加油好好学!

上一篇: 女销售原来靠这样卖房(楼盘置业顾问提成大概多少)
下一篇: 孕妇嘴馋是什么原因,孕后期老是嘴馋怎么回事