FreeCodeCamp——算法中级 算法和数据结构项目

本文详细介绍了FreeCodeCamp的几个中级算法和数据结构项目,包括回文检查器的实现、罗马数字转换、凯撒密码的解码方法、电话号码的有效性检查以及找零问题的解决策略。每个项目都提供了多种解题思路,帮助读者深入理解和应用算法知识。

1、回文检查器

如果传入的字符串是回文字符串,则返回 true。 否则返回 false。
回文 palindrome,指在忽略标点符号、大小写和空格的前提下,正着读和反着读一模一样。

注意:检查回文时,你需要先去除所有非字母数字的字符(标点、空格和符号),并将所有字母都转换成大写或都转换成小写。

方法一:

function palindrome(str) {
   
   
  let newStr = str.toLowerCase().replace(/[^a-zA-Z0-9]/g, '')
  for (let i = 0; i < newStr.length; i++) {
   
   
    while (newStr[i] !== newStr[newStr.length - 1 - i]) {
   
   
      return false
    }
  }
  return true
}

palindrome("eye");
console.log(palindrome("0_0 (: /-\ :) 0-0"))

方法二:

function palindrome(str) {
   
   
  let newStr = str.toLowerCase().replace(/[^a-zA-Z0-9]/g, '')
  //let newStr = str.toLowerCase().replace(/[\W_]/g, '')
  let reverseStr = newStr.split('').reverse().join('')
  return newStr === reverseStr
}
palindrome("eye");
console.log(palindrome("2_A3*3#A2"))

方法三:

 function palindrome(str) {
   
   
  let newStr = str.toLowerCase().replace(/[\W_]/g, '')
  for (let i = 0, j = newStr.length - 1; i < j; i++, j--) {
   
   
    if (newStr[i] !== newStr[j]) {
   
   
      return false
    }
  }
  return true;
}
palindrome("eye");
console.log(palindrome("2_A3*3#A2"))

2、罗马数字转换器

把传入的数字转为罗马数字。

转换后的罗马数字字母必须都是大写。

方法一:

function convertToRoman(num) {
   
   
  const romanNum = [
    ['', 'I', 'II', 'III', 'IV', 
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值