RX学习笔记:FreeCodeCamp的JavaScript基本算法挑战
FreeCodeCamp的JavaScript基本算法挑战
2016-07-03
JavaScript还不是非常熟悉,用已经会的知识来解这些题,估计有些算法会非常笨。
1.反转字符串
str.split("").reverse().join("");
2.阶乘(阶乘0的结果需为1)
function factorialize(num) {
var n=1;
for(var i=num;i>0;i--){
n*=i;}
return n;
}
暂时想不到能不用添加临时变量的方法。
3.判断回文字符串
所谓回文,就是字符串反转后和反转前是一样的,而且忽略除字母数字外的其它字符并且忽略大小写。
因为不懂正则表达式,所以花费了很多时间,看来要好好看一下正则才行。
str.match(/[a-zA-Z0-9]/gi).join("").toLowerCase()==str.match(/[a-zA-Z0-9]/gi).reverse().join("").toLowerCase();
4.查找字符串中最长的单词
str.split(" ").sort(function(a,b){return b.length-a.length;})[0];
5.让字符串中每个单词的首字母大写,其他字母小写
str.split(" ").map(function(arg){return arg.charAt(0).toUpperCase()+arg.substr(1).toLowerCase();}).join(" ");
6.让一个二维整数数组的每个子数组只保留最大的数字
for (var i=0;i<arr.length;i++){
arr[i]=arr[i].sort(function(a,b){return b-a;}).shift();
}
7.判断字符串尾部是否和目标字符串相同
str.substr(-target.length)==target;
8.按给定次数生成重复字符串
function repeatStringNumTimes(str, num) {
var Str="";
while (num>0){
Str+=str;
num--;
}
return Str;
}
又一题需要临时变量,后面再回来看看能如何优化。
9.缩略字符串(从字符串开始截取子字符串并加上“...”3个点号生成新字符串,新字符串长度等于指定长度)
function truncateString(str, num) {
if(str.length>num){
if(num>3){
str=str.slice(0,num-3)+"...";
}else{
str=str.slice(0,num)+"...";
}
}
return str;
}
做到这一题感觉自己的编码和算法都开始真的变糟糕了……
10.矮猴(什么鬼来的,好难)将一维数组按指定长度分割成二维数组
function chunkArrayInGroups(arr, size) {
var myarr=[];
for (var i=0;i<arr.length/size;i++){
myarr[i]=arr.slice(i*size,i*size+size);
}
return myarr;
}
感觉我这方法尽瞎扯,虽然能达到效果,但总觉得怪怪,应该轻松地使用arr返回,我却只能使用临时变量myarr返回。
11.惊悚电影(又来一个什么鬼名字)从数组指定位置截取新数组,看起来好像很难的样子。
function slasher(arr, howMany) {
arr=arr.slice(howMany);
return arr;
}
然后我试着用这么一句,然后就通过了……通过了、通过了?什么情况,不应该这么容易吧?对着起这么吓人的题目名字吗!
12.突变,一维数组有二个字符串元素,判断第一个元素是否包含第二个元素的所有字符,忽略大小写。
function mutation(arr) {
for(var i=0;i<arr[1].length;i++){
if(arr[0].toLowerCase().indexOf(arr[1].substr(i,1).toLowerCase())==-1){
return false;
}
}
return true;
}
13.删除数组中所有Flasy(假)值
arr.filter(function(val){if(val){return val;}});
14.搜查销毁
函数仅有一个参数为整数数组,有个数不固定整数参数需使用隐藏参数访问。过滤数组参数中出现的整数参数相同的数值,返回过滤后的数组。
function destroyer(arr) {
var arg=arguments;
for(var i=1;i<arg.length;i++){
arr=arr.filter(function(value){return value!=arg[i];});
}
return arr;
}
从这一题开始暴力拆解。
15.判断一个整数在一个乱序整数数组中按从小到大的顺序排列应在哪个索引位置插入
function getIndexToIns(arr, num) {
arr=arr.sort(function(a,b){return a-b;});
for(var i=0;i<arr.length;i++){
if(num>arr[i]&&num<arr[i+1]){
return i+1;
} else if(num==arr[i]){
return i;
} else if(i==arr.length-1){
return i+1;
}
}
return num;
}
完全暴力解题,无语了。
16.凯撒密码 ROT13(没听说过?)
ROT13就是将26个字母分成两段,每段13个,然后对应位置进行调换的简单加密方法。换算成字符编码就是直接加或减13再转换回字符。
function rot13(str) {
function rot13char(char){
if (char.charCodeAt()>=65&&char.charCodeAt()<=90){
return char.charCodeAt()>=78?String.fromCharCode(char.charCodeAt()-13):String.fromCharCode(char.charCodeAt()+13);
}else
return char;
}
str=str.split("").map(rot13char).join("");
return str;
}
增加一个过滤子函数单独处理字符,感觉相当啰嗦,应该有一行就能解决的方法吧?
终于熬完最后一题了,总共用了快要一天的时间。
RX学习笔记:FreeCodeCamp的JavaScript基本算法挑战的更多相关文章
- RX学习笔记:JavaScript数组操作
RX学习笔记:JavaScript数组操作 2016-07-03 增删元素 unshift() 在数组开关添加元素 array.unshift("value"); array.un ...
- OpenCV学习笔记(27)KAZE 算法原理与源码分析(一)非线性扩散滤波
http://blog.csdn.net/chenyusiyuan/article/details/8710462 OpenCV学习笔记(27)KAZE 算法原理与源码分析(一)非线性扩散滤波 201 ...
- 机器学习实战(Machine Learning in Action)学习笔记————06.k-均值聚类算法(kMeans)学习笔记
机器学习实战(Machine Learning in Action)学习笔记————06.k-均值聚类算法(kMeans)学习笔记 关键字:k-均值.kMeans.聚类.非监督学习作者:米仓山下时间: ...
- 再探快速傅里叶变换(FFT)学习笔记(其三)(循环卷积的Bluestein算法+分治FFT+FFT的优化+任意模数NTT)
再探快速傅里叶变换(FFT)学习笔记(其三)(循环卷积的Bluestein算法+分治FFT+FFT的优化+任意模数NTT) 目录 再探快速傅里叶变换(FFT)学习笔记(其三)(循环卷积的Blueste ...
- HMM的学习笔记1:前向算法
HMM的学习笔记 HMM是关于时序的概率模型.描写叙述由一个隐藏的马尔科夫链随机生成不可观測的状态随机序列,再由各个状态生成不可观測的状态随机序列,再由各个状态生成一个观測而产生观測的随机过程. HM ...
- jvm学习笔记一(垃圾回收算法)
一:垃圾回收机制的原因 java中,当没有对象引用指向原先分配给某个对象的内存时候,该内存就成为了垃圾.JVM的一个系统级线程会自动释放该内存块.垃圾回收意味着程序不再需要的对象是"无用信息 ...
- RX学习笔记:在FreeCodeCamp的学习
FreeCodeCamp https://www.freecodecamp.com 2016-07-03 前几日在Github浏览时,偶然看到一个叫FreeCodeCamp的开源项目,进去该网站之后感 ...
- 挑子学习笔记:两步聚类算法(TwoStep Cluster Algorithm)——改进的BIRCH算法
转载请标明出处:http://www.cnblogs.com/tiaozistudy/p/twostep_cluster_algorithm.html 两步聚类算法是在SPSS Modeler中使用的 ...
- Javascript学习笔记2.2 Javascript与DOM选项卡(滑动门)案例详解
学习了DOM的知识,今天开始做些练习,想到了一个网页滑动门的特效,见下图: 1.通过建立索引实现 <!doctype html> <html> <head> < ...
随机推荐
- PostgreSQL的prepare 和 execute 动作背后
我给PostgreSQL的源代码加入了调试信息以后,会有如下表现: 我执行Prepare: postgres=# prepare s(; PREPARE postgres=# 背后的反应: ** In ...
- json处理复杂对象jsonConfig
我们通常的Json字符串和java当对象互转.经常有选择性地过滤掉一些属性值,和json-lib包JsonConfig为我们提供了这样一个 特征,有几种方法实施细则. (1)建立JsonConf ...
- Android 通用获取Ip的方法(判断手机是否联网的方法)!!!
大家好,我们这一节讲一下,Android获取Ip的一些方法,在我们开发中,有判断手机是否联网,或者想获得当前手机的Ip地址,当然WIFI连接的和 我们3G卡的Ip地址当然是不一样的. 首先我尝试了如下 ...
- Android 电子邮件发送成功与失败的提示
前言 欢迎大家我分享和推荐好用的代码段~~ 声明 欢迎转载.但请保留文章原始出处: CSDN:http://www.csdn.net ...
- C#_delegate - 值参数和引用参数
值参数不能加,引用参数可以. 引用参数是共享的 using System; using System.Collections.Generic; using System.Linq; using Sys ...
- Android_Intent_data_type
layout.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" x ...
- ViewFlipper的简单使用实现图片轮播效果
/** * ViewFlipper: * 安卓系统自带的一个多页面管理控件,它可以实现子页面的自动切换 * 为ViewFlipper加入View: * (1)在layout布局文件静态导入子View ...
- famous javascript library.
https://famo.us/ THE ULTIMATE WEB PLATFORM FOR DEVELOPERS AND DESIGNERS
- 《Mysql 公司职员学习篇》 第一章 小A的烦恼
第一章 小A的烦恼 ----- 为什么学习数据库 和 如何选择数据库 小A是某公司的职员,公司数据部的员工,平常的大小工作,完全离不开EXCELL,而最近小A却越来越苦恼,不由的向好朋友小Y吐槽.小 ...
- handlebar helper帮助方法
handlebars相对来讲算一个轻量级.高性能的模板引擎,因其简单.直观.不污染HTML的特性.另一方面,handlebars作为一个logicless的模板,不支持特别复杂的表达式.语句,只内置了 ...