w3cschool脚本算法编程实战课程
部分源码==》https://github.com/calamus0427/commonJS
翻转字符串算法挑战
function reverseString(str) {
str = str.split("").reverse().join("")
return str;
} reverseString("hello");
阶乘算法挑战
function factorialize(num) {
let sum = num ;
if(num == 0){
return 1 ;
}else{
while(num > 1 ){
sum *= (num-1) ;
num -- ;
}
} return sum;
} factorialize(0);
回文算法挑战
function palindrome(str) {
str = str.replace(/[^a-zA-Z\d]/g, "");
return str.toLowerCase() == str
.split("")
.reverse()
.join("")
.toLowerCase();
}
palindrome("0_0 (: /-\ :) 0-0");
寻找最长的单词算法挑战
function findLongestWord(str) {
str = str.split(" ");
let len = str[0].length ;
for(let i = 0 ; i < str.length ; i++){
if(len <= str[i].length){
len = str[i].length ;
}
}
return len;
} findLongestWord("The quick brown fox jumped over the lazy dog");
设置首字母大写算法挑战
function titleCase(str) {
str = str.split(" ");
for(let i = 0 ; i < str.length ; i++){
str[i] =str[i].substring(0, 1).toUpperCase() + str[i].substring(1).toLowerCase();
}
str = str.join(" ");
return str;
} titleCase("sHoRt AnD sToUt");
寻找数组中的最大值算法挑战
function largestOfFour(arr) {
let newArr = [] ;
for(let i = 0 ; i < arr.length ; i ++){
let max = arr[i][0];
for(let j = 0 ; j < arr[i].length ; j++){
if(max <= arr[i][j]){
max = arr[i][j];
}
}
newArr.push(max);
}
return newArr;
} largestOfFour([[4, 5, 1, 3], [13, 27, 18, 26], [32, 35, 37, 39], [1000, 1001, 857, 1]]);
确认末尾字符算法挑战
function confirmEnding(str, target) {
// "Never give up and good luck will find you."
// -- Falcor
console.log(str,"|||",str.substring(str.length-target.length))
// return str.substring(str.length-target.length) == target;
return str.endsWith(target);
} confirmEnding("Bastian", "n");
重复操作算法挑战
function repeat(str, num) {
// repeat after me
if(num < 0){
return ""
}else{
let newStr = "" ;
for(let i = 0 ; i < num ; i++){
newStr += str ;
}
return newStr;
} } repeat("abc", 3);
字符串截取算法挑战
function truncate(str, num) {
// Clear out that junk in your trunk
if(str.length <= num ){
return str;
}else{
if(num <=3 ){
return str.substring(0,num)+"...";
} else{
return str.substring(0,num-3)+"...";
}
} } truncate("Peter Piper picked a peck of pickled peppers", 14);
数组分割算法挑战
function chunk(arr, size) {
// Break it up.
var index = 0;
var newArray = []; while(index < arr.length) {
newArray.push(arr.slice(index, index += size));
} return newArray;
} chunk(["a", "b", "c", "d"], 2);
数组截断算法挑战
function slasher(arr, howMany) {
// it doesn't always pay to be first
return arr.slice(howMany);
} slasher([1, 2, 3], 2);
数组查询算法挑战
function mutation(arr) {
let first = arr[0].toLowerCase();
let target = arr[1].toLowerCase().split("") ;
for(let i = 0 ; i < target.length ; i++){
if(first.indexOf(target[i]) < 0 ){
return false ;
}
}
return true ; } mutation(["zyxwvutsrqponmlkjihgfedcba", "qrstu"]);
删除数组中特定值算法挑战
function bouncer(arr) {
// Don't show a false ID to this bouncer.
return arr.filter(params => Boolean(params));
} function isBad(params){
var result = Boolean(params);
return result;
} bouncer([7, "ate", "", false, 9]);
去除数组中任意多个值算法挑战
function destroyer(arr) {
var args = [];
for(var i = 1; i < arguments.length; i++){ //将待摧毁的值放入一个数组中,赋值给变量args
args.push(arguments[i]);
}
var newArr=arr.filter(function(item){ //两个数组去重;
return args.indexOf(item) === -1;
});
return newArr;
} destroyer([1, 2, 3, 1, 2, 3], 2, 3);
数组排序并插入值算法挑战
function where(arr, num) {
// Find my place in this sorted array.
arr.push(num);
arr = arr.sort(function(x,y){ //将num扔进arr中之后排序;
return x-y;
});
console.log(arr);
return arr.indexOf(num);
} where([3, 10, 5], 3);
位移密码算法挑战
function rot13(str) { // LBH QVQ VG!
var newArr=[];
for(var i=0;i<str.length;i++){
var numbers=str.charCodeAt(i); //使用charCodeAt()方法取得每个字符的Unicode值,并保存在变量numbers中;
if(numbers<65||numbers>90){
newArr.push(String.fromCharCode(numbers));
}else if(numbers>77){
newArr.push(String.fromCharCode(numbers-13));
}else{
newArr.push(String.fromCharCode(numbers+13));
}
} //大写A-Z字母对应的Unicode值为65-90;通过判断,利用fromCharCode()将Unicode值又转换为字符;
return newArr.join("");
} // Change the inputs below to test
rot13("SERR PBQR PNZC");
w3cschool脚本算法编程实战课程的更多相关文章
- 七、Shell脚本高级编程实战第七部
一.写网络服务的系统启动脚本 利用case语句开发类似系统启动rsync服务的脚本 代码: #!/bin/sah. /etc/init.d/functionspidfile="/var/ru ...
- 九、Shell脚本高级编程实战第九部
一.监控mysql主从同步是否异常,如果异常,发送短信给管理员 1)开发一个守护进程脚本每30秒实现检测一次. 2)如果错误号是:1158.1159.1008.1007.1062,请跳过 3)请使用数 ...
- 六、Shell脚本高级编程实战第六部
一.写一个start_nginx脚本,当启动.停止.重启时利用系统函数模拟实现系统脚本启动的特殊颜色效果 (用if实现) #!/bin/sh. /etc/init.d/functions if [ $ ...
- 四、Shell脚本高级编程实战第四部
一.比较两个数的大小 #!/bin/shread -p "Pls input two num:" a b[ -z "$a" ] || [ -z "$b ...
- 三、Shell脚本高级编程实战第三部
保养好自己的发动机:身体的和心里的身体健康:打打球,跑跑步心里健康:多和大家接触,保持家人.朋友的良好关系一.$*和$@的区别 $*:获取shell的所有参数,将所有的参数视为单个字符串. $ ...
- 二、Shell脚本高级编程实战第二部
一.什么是变量? 变量就是一个固定的字符串替代更多更复杂的内容,当然内容里面可能还有变量.路径.字符串等等内容,最大的特点就是方便,更好开展工作 1.变量有环境变量(全局变量)和局部变量 环境变量就是 ...
- 一、Shell脚本高级编程实战第一部
Shell脚本语言是实现linux系统自动化管理的重要且必要的工具,几乎每一个合格的linux系统管理员或者高级运维工程师都要熟练shell脚本语言的编写,只有这样才能提升工作效率,解决工作中的重复劳 ...
- 八、Shell脚本高级编程实战第八部
一.使用for循环在/oldboy目录下创建10个文件名为oldboy-x的文件 #!/bin/sh[ ! -d /oldboy ] && mkdir -p /oldbfor i in ...
- 五、Shell脚本高级编程实战第五部
一.条件表达式 在bash的各种流程控制结构中通常要进行各种测试,然后根据测试结果执行不同的操作.有时也和if结合,让我们方便判断. test: 1)判断文件是否存在:test -f file 2) ...
随机推荐
- VMware虚拟机里centos7下安装mysql5.6并授权远程连接Navicat
这节来安装Mysql5.6,并远程授权连接本地windows的Navicat,可以根据以下步骤安装.此文章为自己收藏,必要时拿出来直接用的,有需要的友友可以查看查看的.文章图片有借助于网络的. 1.新 ...
- Hadoop HDFS DataNode 目录结构
DataNode 目录结构 和namenode不同的是,datanode的存储目录是初始阶段自动创建的,不需要额外格式化. 1. 在/opt/module/hadoop-2.7.2/data/t ...
- MapReduce实现与自定义词典文件基于hanLP的中文分词详解
前言: 文本分类任务的第1步,就是对语料进行分词.在单机模式下,可以选择python jieba分词,使用起来较方便.但是如果希望在Hadoop集群上通过mapreduce程序来进行分词,则hanLP ...
- cmp命令详解
Linux cmp命令 Linux cmp命令用于比较两个文件是否有差异.主要用来比较两个二进制文件 当相互比较的两个文件完全一样时,则该指令不会显示任何信息.若发现有所差异,预设会标示出第一个不同之 ...
- 【转】python:让源码更安全之将py编译成so
python:让源码更安全之将py编译成so 应用场景 Python是一种面向对象的解释型计算机程序设计语言,具有丰富和强大的库,使用其开发产品快速高效. python的解释特性是将py编译为独有的二 ...
- Spring Cloud(Dalston.SR5)--Eureka 注册中心高可用搭建
高可用集群 在微服务架构这样的分布式环境中,我们需要充分考虑发生故障的情况,所以在生产环境中必须对各个组件进行高可用部署,对与微服务和服务注册中心都需要高可用部署,Eureka 高可用实际上就是将自己 ...
- kettle判断是否是数据首行(第一行)
可以用组件:分析查询(Analytic Query) 后面可以通过判断pre_id 是否为空值(null)判断.
- spring邮件发送
1,Emaill类: package com.learn.jsp.pojo; /** * 邮件基本信息 * @author kevin * */public class Email { private ...
- XE5开发Android程序调用电话相关功能(短信息和电话) [转]
其实都可以通过intent和URI调用系统功能.Windows程序员可以理解成是ShellExecute.这个是万金油.可以有调用各种功能.后面会介绍. 1.短信息.很简单 方法a.不使用Intent ...
- 最新证明面临质疑:P/NP问题为什么这么难?
转自:http://tech.sina.com.cn/d/2017-08-16/doc-ifyixias1432604.shtml 编译 | 张林峰(普林斯顿大学应用数学专业博士研究生) 责编 | 陈 ...