FreeCodeCamp 前端初级算法(个人向)
freecodecamp 初级算法地址戳这里
Reverse a String
翻转字符串
function reverseString(str) {
str=str.split("").reverse().join("");
return str;
}
reverseString("hello")
Factorialize a Number
计算一个整数的阶乘
function factorialize(num) {
if(num>1){
num=num*factorialize(num-1);
}else{
num=1;
}
return num;
}
factorialize(5);
Check for Palindromes
如果给定的字符串是回文,返回true,反之,返回false。
function palindrome(str) {
// Good luck!
var str1=str.toLowerCase().replace( /[\(\)\s.,/_-]/g,"" );
var str2=str1.split("").reverse().join("");
return str1==str2;
}
8 palindrome("eye");
Find the Longest Word in a String
找到提供的句子中最长的单词,并计算它的长度。
function findLongestWord(str) {
var arr=str.split(" ");
var max=0;
for(let a of arr){
max=a.length>max?a.length:max;
}
return max;
}
findLongestWord("The quick brown fox jumped over the lazy dog");
Title Case a Sentence
确保字符串的每个单词首字母都大写,其余部分小写。
function titleCase(str) {
var arr=str.split(" ");
for(var i in arr){
var len=arr[i].length;
var word=arr[i].toLowerCase();
if( len==1 ){
arr[i]=word.toUpperCase();
}else{
arr[i]=word.substring(0,1).toUpperCase()+word.substring(1,len);
}
}
str=arr.join(" ");
return str;
}
titleCase("I'm a little tea pot");
Return Largest Numbers in Arrays
右边大数组中包含了4个小数组,分别找到每个小数组中的最大值,然后把它们串联起来,形成一个新数组。
function largestOfFour(arr) {
// You can do this!
var max=[];
for(var i in arr){
let bigger;
for(var j in arr[i]){
bigger=bigger?( arr[i][j]>bigger?arr[i][j]:bigger ):arr[i][j];
}
max.push(bigger);
}
return max;
}
largestOfFour([[4, 5, 1, 3], [13, 27, 18, 26], [32, 35, 37, 39], [1000, 1001, 857, 1]]);
Confirm the Ending
检查一个字符串(str)是否以指定的字符串(target)结尾
function confirmEnding(str, target) {
// "Never give up and good luck will find you."
// -- Falcor
var str1=str.replace( new RegExp(target,"g"),"|");
var flag=str1.lastIndexOf("|");
return flag==str1.length-1?true:false;
}
confirmEnding("Bastian", "n");
Repeat a string repeat a string
重复一个指定的字符串 num次,如果num是一个负数则返回一个空字符串。
function repeat(str, num) {
// repeat after me
var str1=str;
if( num<=0 ){
str1="";
}
while( num>1 ){
str1+=str;
num--;
}
return str1;
}
repeat("abc", 3);
Truncate a string
如果字符串的长度比指定的参数num长,则把多余的部分用...来表示。
function truncate(str, num) {
// Clear out that junk in your trunk
var index;
if( str.length>num ){
if ( num<=3 ){
index=num;
}else{
index=num-3; //-3是减去...的长度
}
str=str.slice(0,index)+"...";
}
return str;
}
truncate("A-tisket a-tasket A green and yellow basket", 11);
Chunky Monkey
把一个数组arr按照指定的数组大小size分割成若干个数组块。
function chunk(arr, size) {
// Break it up.
var arr2=[];
var max=Math.ceil( arr.length/size );
for(var i=0;i<max;i++){
arr2.push( arr.slice(i*size,i*size+size) );
}
return arr2;
}
chunk(["a", "b", "c", "d"], 2);
Slasher Flick
返回一个数组被截断n个元素后还剩余的元素,截断从索引0开始。
function slasher(arr, howMany) {
// it doesn't always pay to be first
arr.splice(0,howMany);
return arr;
}
slasher([1, 2, 3], 2);
Mutations
如果数组第一个字符串元素包含了第二个字符串元素的所有字符,函数返回true。
function mutation(arr) {
var main=arr[0].toLowerCase();
var search=arr[1].toLowerCase().split("");
for(var a in search){
if( main.indexOf( search[a] )==-1 ){
return false;
}
}
return true;
}
mutation(["hello", "hey"]);
Falsy Bouncer
删除数组中的所有假值。
function bouncer(arr) {
// Don't show a false ID to this bouncer.
return arr.filter(isTrue);
}
function isTrue(ele){
if( ele ){
return ele;
}
}
bouncer([7, "ate", "", false, 9]);
Seek and Destroy
实现一个摧毁(destroyer)函数,第一个参数是待摧毁的数组,其余的参数是待摧毁的值。
function destroyer() {
// Remove all the values
var arr=[].shift.apply( arguments );
var vals=arguments;
var arr2=arr.filter(function(ele){
for(var i=0,l=vals.length;i<l;i++){
if( ele==vals[i] ){
return false;
}
}
return true;
});
console.log(arr2);
return arr2;
}
destroyer([1, 2, 3, 1, 2, 3], 2, 3);
Where do I belong
先给数组排序,然后找到指定的值在数组的位置,最后返回位置对应的索引。
function where(arr, num) {
// Find my place in this sorted array.
arr.push(num);
var index=arr.sort(function(a,b){
return a-b;
}).indexOf(num);
return index;
}
where([40, 60], 50);
Caesars Cipher
下面我们来介绍风靡全球的凯撒密码Caesar cipher,又叫移位密码。
写一个ROT13函数,实现输入加密字符串,输出解密字符串。
function rot13(str) { // LBH QVQ VG!
var arr=str.split(" ");
var result=[];
for(var i in arr){
result.push( word(arr[i],13) );
}
return result.join(" ");
}
function word(str,num){
var res="";
for(var i=0,l=str.length;i<l;i++){
res+=String.fromCharCode( char(str.charCodeAt(i),num) );
}
return res;
}
function char(old,add){
//65-90 A-Z
//97-122 a-z
var res;
var cha;
if( old>=65 && old<=90 ){
cha=old+add-90;
res=cha<=0?old+add:65+cha-1;
}else if( old>=97 && old<=122 ){
cha=old+add-122;
res=cha<=0?old+add:97+cha-1;
}else{
res=old;
}
return res;
}
// Change the inputs below to test
rot13("SERR PBQR PNZC");
FreeCodeCamp 前端初级算法(个人向)的更多相关文章
- 互联网公司前端初级Javascript面试题
互联网公司前端初级Javascript面试题 1.JavaScript是一门什么样的语言,它有哪些特点?(简述javascript语言的特点)JavaScript是一种基于对象(Object)和事件驱 ...
- LeetCode初级算法的Python实现--排序和搜索、设计问题、数学及其他
LeetCode初级算法的Python实现--排序和搜索.设计问题.数学及其他 1.排序和搜索 class Solution(object): # 合并两个有序数组 def merge(self, n ...
- LeetCode初级算法的Python实现--链表
LeetCode初级算法的Python实现--链表 之前没有接触过Python编写的链表,所以这里记录一下思路.这里前面的代码是和leetcode中的一样,因为做题需要调用,所以下面会给出. 首先定义 ...
- LeetCode初级算法的Python实现--字符串
LeetCode初级算法的Python实现--字符串 # 反转字符串 def reverseString(s): return s[::-1] # 颠倒数字 def reverse(x): if x ...
- LeetCode初级算法的Python实现--数组
LeetCode初级算法的Python实现--数组 # -*- coding: utf-8 -*- """ @Created on 2018/6/3 17:06 @aut ...
- LeetCode初级算法(动态规划+设计问题篇)
目录 爬楼梯 买卖股票的最佳时机 最大子序和 打家劫舍 动态规划小结 Shuffle an Array 最小栈 爬楼梯 第一想法自然是递归,而且爬楼梯很明显是一个斐波拉切数列,所以就有了以下代码: c ...
- LeetCode初级算法(数组)解答
这里记录了LeetCode初级算法中数组的一些题目: 加一 本来想先转成整数,加1后再转回去:耽美想到测试的例子考虑到了这个方法的笨重,所以int类型超了最大范围65536,导致程序出错. class ...
- 【LeetCode算法】LeetCode初级算法——字符串
在LeetCode初级算法的字符串专题中,共给出了九道题目,分别为:反转字符串,整数反转,字符串中的第一个唯一字符,有效的字母异位词,验证回文字符串,字符串转换整数,实现strStr(),报数,最 ...
- LeetCode探索初级算法 - 动态规划
LeetCode探索初级算法 - 动态规划 今天在LeetCode上做了几个简单的动态规划的题目,也算是对动态规划有个基本的了解了.现在对动态规划这个算法做一个简单的总结. 什么是动态规划 动态规划英 ...
随机推荐
- 小甲鱼python视频弟十一讲(课后习题)
1.修改列表里的值 list1 = [,,[,,,[,,,,] list1[] = print(list1) list1[][][] = '?' print(list1) 2.列表的排序(sort) ...
- PHP 四种基本排序算法的代码实现
前提:分别用冒泡排序法,快速排序法,选择排序法,插入排序法将下面数组中的值按照从小到大的顺序进行排序. $arr(1,43,54,62,21,66,32,78,36,76,39); 1. 冒泡排序 思 ...
- js取最小最大值--Math.min()、math.max()
一.Math.min() 返回一组表达式中最小者 eg: var n = Math.min( 2 , 30 ,1 , 200-10 , 300*22 , 20-30 ); alert(n); //打印 ...
- Oracle列操作(增加列,修改列,删除列)
Oracle列操作 增加一列: alter table emp4 add test varchar2(10); 修改一列: alter table emp4 modify test varchar2( ...
- js中json对象的深拷贝
/** * 对象深拷贝 * @param obj */ function deepCopy(obj) { var txt=JSON.stringify(obj); return JSON.parse( ...
- expect工具的简单用法
原创文档,转载请注明作者与本文URL. linux中的expect工具很不错,能够自动实现交互,也即是说自己自动进行ssh登录等动作.这是我写的一个简单的用法,稍作修改就可以变成很实用都脚本.有人介绍 ...
- KEIL MDK输出map文件分析
一.文件分析流程 1.第一部分:Section Cross References 主要是各个源文件生成的模块之间相互引用的关系. stm32f10x.o(STACK) refers (Special) ...
- 使用PPT制作交叉密文图
曾几何时,一张图火遍大江南北,互相流传. 其中的奥秘早已破解出来,但是仍乐趣无穷. 来回顾这样一张图吧! 最近,在朋友圈中,这样的一种图又流行起来,被改成不同的版本. 可是这样一种图片到底是怎样做出来 ...
- andriod终端操作命令
1.卸载大厅安装包,如果卸载不掉的话,添加-r pm uninstall -r com.scigames.egm.lobby 2.查找包含"scigames"的安装包 3.卸载一个 ...
- 精确运算--BigDecimal
工具类 ,直接就可以使用,对于float和double的进行加减乘除长生的误差的解决办法. import java.math.BigDecimal; public class Arith { // 默 ...