”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 字符串 - JavaScript 挑战

字符串 - JavaScript 挑战

发布于2024-11-08
浏览:691

String - JavaScript Challenges

您可以在 repo Github 上找到这篇文章中的所有代码。


字符串相关的挑战


是字母数字

/**
 * @param {any} char
 * @return {Boolean}
 */

function isAlphaNumeric(char) {
  return /[A-Za-z0-9]/.test(char);
}

// Usage example
console.log(isAlphaNumeric("a")); // => true
console.log(isAlphaNumeric(0)); // => true
console.log(isAlphaNumeric("!")); // => false

骆驼案例 蛇案例

// camel case to snake case
/**
 * @param {string} str
 * @return {string}
 */
function toKebabCase(str) {
  let temp = str.replace(/[A-Z]/g, function (i) {
    return "_"   i.toLowerCase();
  });

  if (temp[0] === "_") {
    temp = temp.slice(1);
  }

  return temp;
}

// Usage example
console.log(toKebabCase("testMethod")); // => "test_method"

// snake case to camel case
/**
 * @param {string} str
 * @return {string}
 */
function toCamelCase(str) {
  return str.replace(
    /([a-z])_([a-z])/gi,
    (_, left, right) => left   right.toUpperCase()
  );
}

// Usage example
console.log(toCamelCase("test_method")); // => "testMethod"

比较版本号

/**
 * @param {string} version1
 * @param {string} version2
 * @return {number}
 */

function compareVersion(version1, version2) {
  const v1Arr = version1.split(".");
  const v2Arr = version2.split(".");

  for (let i = 0; i  v2Num) {
      return 1;
    } else if (v1Num  1, meaning first one is greater
console.log(compareVersion("12.1.0", "12.1.2")); // => -1, meaning latter one is greater
console.log(compareVersion("5.0.1", "5.0.1")); // => 0, meaning they are equal.

版本号排序

/**
 * @param {string[]} versions
 * @return {string[]}
 */

function sortVersions(versions) {
  return versions.sort((a, b) => {
    const aParts = a.split(".").map(Number);
    const bParts = b.split(".").map(Number);

    for (let i = 0; i  [ '0.1.1', '0.302.1', '2.3.3', '4.2', '4.3.4.5', '4.3.5' ]

压缩字符串
/**
 * @param {string} str
 * @return {string}
 */

function compress(str) {
  if (!str) {
    return "";
  }

  let compressed = "";
  let count = 1;

  for (let i = 1; i  1) {
        compressed  = count;
      }
      count = 1;
    }
  }

  return compressed;
}

// Usage example
console.log(compress("a")); // 'a'
console.log(compress("aa")); // 'a2'
console.log(compress("aaa")); // 'a3'
console.log(compress("aaab")); // 'a3b'
console.log(compress("aaabb")); // 'a3b2'
console.log(compress("aaabba")); // 'a3b2a'
/** * @param {string} 字符串 * @return {字符串} */ 函数压缩(str){ 如果 (!str) { 返回 ””; } 让压缩=“”; 让计数 = 1; for (让 i = 1; i 1){ 压缩=计数; } 计数 = 1; } } 返回压缩; } // 使用示例 console.log(压缩(“a”)); // '一个' console.log(压缩(“aa”)); // 'a2' console.log(压缩(“aaa”)); // 'a3' console.log(压缩(“aaab”)); // 'a3b' console.log(压缩(“aaabb”)); // 'a3b2' console.log(压缩(“aaabba”)); // 'a3b2a'

解压缩字符串
/**
 * @param {string} str
 * @return {string}
 */

function compress(str) {
  if (!str) {
    return "";
  }

  let compressed = "";
  let count = 1;

  for (let i = 1; i  1) {
        compressed  = count;
      }
      count = 1;
    }
  }

  return compressed;
}

// Usage example
console.log(compress("a")); // 'a'
console.log(compress("aa")); // 'a2'
console.log(compress("aaa")); // 'a3'
console.log(compress("aaab")); // 'a3b'
console.log(compress("aaabb")); // 'a3b2'
console.log(compress("aaabba")); // 'a3b2a'
/** * @param {string} 字符串 * @returns {字符串} */ 函数解压缩(str){ 常量堆栈=[]; 让当前数量 = 0; 让当前Str =“”; for (str 的 const char) { if (char >= "0" && char 'ababab' console.log(解压缩(“3(ab2(c))”)); // => 'abccabccabcc'

查找字符串中最长单词的长度
/**
 * @param {string} str
 * @return {string}
 */

function compress(str) {
  if (!str) {
    return "";
  }

  let compressed = "";
  let count = 1;

  for (let i = 1; i  1) {
        compressed  = count;
      }
      count = 1;
    }
  }

  return compressed;
}

// Usage example
console.log(compress("a")); // 'a'
console.log(compress("aa")); // 'a2'
console.log(compress("aaa")); // 'a3'
console.log(compress("aaab")); // 'a3b'
console.log(compress("aaabb")); // 'a3b2'
console.log(compress("aaabba")); // 'a3b2a'
/** * @param {string} 字符串 * @return {数字} */ 函数最长长度(str){ const strArr = str.split(" "); 令长度=0; for (让 i = 0; i 长度) { 长度 = strArr[i].length; } } 返回长度; } // 使用示例 console.log(longestLength("最长的单词是 thelongestword")); // => 14

查找字符串中长度最长的单词
/**
 * @param {string} str
 * @return {string}
 */

function compress(str) {
  if (!str) {
    return "";
  }

  let compressed = "";
  let count = 1;

  for (let i = 1; i  1) {
        compressed  = count;
      }
      count = 1;
    }
  }

  return compressed;
}

// Usage example
console.log(compress("a")); // 'a'
console.log(compress("aa")); // 'a2'
console.log(compress("aaa")); // 'a3'
console.log(compress("aaab")); // 'a3b'
console.log(compress("aaabb")); // 'a3b2'
console.log(compress("aaabba")); // 'a3b2a'
/** * @param {string} 字符串 * @return {字符串[]} */ 函数最长的单词(str){ const strArr = str.split(" "); 常量结果 = []; 让最大值= 0; for (strArr 的 const char) { if (char.length > max) { 最大=字符长度; } } for (strArr 的 const char) { if (char.length === max) { 结果.push(char); } } 返回结果.join(""); } // 使用示例 console.log(longestWord("最长的单词是thelongestword")); // => “最长的单词”

最常出现的字符
/**
 * @param {string} str
 * @return {string}
 */

function compress(str) {
  if (!str) {
    return "";
  }

  let compressed = "";
  let count = 1;

  for (let i = 1; i  1) {
        compressed  = count;
      }
      count = 1;
    }
  }

  return compressed;
}

// Usage example
console.log(compress("a")); // 'a'
console.log(compress("aa")); // 'a2'
console.log(compress("aaa")); // 'a3'
console.log(compress("aaab")); // 'a3b'
console.log(compress("aaabb")); // 'a3b2'
console.log(compress("aaabba")); // 'a3b2a'
/** * @param {string} 字符串 * @returns {字符串|细绳[]} */ 函数计数(str){ 常量地图=新地图(); 常量结果 = []; for (str 的 const char) { map.set(char, (map.get(char) ?? 0) 1); } const max = Math.max(...map.values()); for (map 的 const [键, 值]) { 如果(值===最大值){ 结果.push(key); } } 返回结果.length === 1 ?结果[0]:结果; } // 使用示例 console.log(count("abbccc")); // => 'c' console.log(count("abbcccddd")); // => ['c', 'd'];

获取字符串长度(支持表情符号)
/**
 * @param {string} str
 * @return {string}
 */

function compress(str) {
  if (!str) {
    return "";
  }

  let compressed = "";
  let count = 1;

  for (let i = 1; i  1) {
        compressed  = count;
      }
      count = 1;
    }
  }

  return compressed;
}

// Usage example
console.log(compress("a")); // 'a'
console.log(compress("aa")); // 'a2'
console.log(compress("aaa")); // 'a3'
console.log(compress("aaab")); // 'a3b'
console.log(compress("aaabb")); // 'a3b2'
console.log(compress("aaabba")); // 'a3b2a'
/** * @param {String} 字符串 * @return {数字} */ 函数 getStringLength(str) { return Array.from(new Intl.Segmenter().segment(str)).length; } // 使用示例 console.log(getStringLength("测试?")); // => 5 console.log("测试?".length); // => 6

参考
  • 字母数字 - Wikipedia.org
  • 命名约定(编程)- Wikipedia.org
  • 79。将蛇形命名法转换为驼峰命名法 - BFE.dev
  • 软件版本控制 - Wikipedia.org
  • 157. semver 比较 - BFE.dev
  • 165.比较版本号 - LeetCode
  • 97。压缩字符串 - BFE.dev
  • 173.解压缩字符串 - BFE.dev
  • 145.最常出现的字符 -BFE.dev

版本声明 本文转载于:https://dev.to/mitchell_cheng/string-javascript-challenges-54cf?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何使用 Python 库维护 JSON 对象中键的顺序?
    如何使用 Python 库维护 JSON 对象中键的顺序?
    使用 Python 库保留 JSON 对象属性的顺序使用 json.dumps 将 Python 对象转换为 JSON 字符串时,输出 JSON 对象中键的顺序可能与输入 Python 对象中键的原始顺序不一致。如果需要特定的键顺序,这可能会出现问题。要解决此问题,您可以利用某些 Python 库,...
    编程 发布于2024-11-08
  • ## 什么是 __construct 方法以及它在 PHP 中如何工作?
    ## 什么是 __construct 方法以及它在 PHP 中如何工作?
    理解__construct在类定义中的作用在面向对象编程中,__construct方法在类定义中起着至关重要的作用。它作为构造函数,负责在创建对象时初始化和设置对象的属性。什么是 __construct?__construct 是 PHP5 中引入的一个特殊方法每当从类实例化新对象时都会自动调用它。...
    编程 发布于2024-11-08
  • 使用 Python 进行词嵌入:Wordc
    使用 Python 进行词嵌入:Wordc
    使用 Python(和 Gensim)实现 word2vec 注意:此代码是用Python 3.6.1(Gensim 2.3.0)编写的 word2vec与Gensim的Python实现及应用 原始论文:Mikolov, T.、Chen, K.、Corrado, G. 和 Dean...
    编程 发布于2024-11-08
  • 如何解决 C# 中 MySQL UTF-8 数据的编码问题?
    如何解决 C# 中 MySQL UTF-8 数据的编码问题?
    MySQL 和 C# 中的编码问题在您的项目中,从以 UTF 编码的 MySQL 数据库检索数据时遇到字符差异-8 使用ADO.Net实体框架。具体来说,像“ë”这样的字符显示为“à”。可能的解决方案要纠正此问题,有两个关键步骤: 1。验证数据库排序规则确保数据库或表的排序规则设置为 UTF-8 排...
    编程 发布于2024-11-08
  • 适合初学者的 VueJs VueJs 部分创建、导入和使用组件
    适合初学者的 VueJs VueJs 部分创建、导入和使用组件
    创建您的第一个组件 什么是组件? 组件是 Vue 应用程序的构建块。每个组件都有自己的功能和视图,组件可以在整个应用程序中重用。组件的一个示例是可以在不同页面上访问的导航栏。 创建基本组件 在组件文件夹中创建一个名为 HelloWorld.vue 的新组件文件(如果需要,您可以更改...
    编程 发布于2024-11-08
  • 如何在Python中为共享模块创建命名空间包?
    如何在Python中为共享模块创建命名空间包?
    在 Python 中创建命名空间包以进行共享模块分发简介在 Python 中,命名空间包是分发相关模块的便捷方法。它们使多个 Python 产品能够在同一命名空间中定义模块,从而允许最终用户无缝导入它们。实现命名空间包Python 3.3 中的隐式命名空间包从Python 3.3开始,引入了隐式命名...
    编程 发布于2024-11-08
  • 数据库设计中“n:m”和“1:n”关系有什么区别?
    数据库设计中“n:m”和“1:n”关系有什么区别?
    数据库设计:阐明“n:m”和“1:n”关系的含义在数据库设计领域,实体之间的关系是根本性的。理解用于描述这些关系的符号对于创建健壮且高效的数据库结构至关重要。两个常见的符号是“n:m”和“1:n”。n:m 关系:多对多连接An "n :m”关系表示两个表之间的多对多关系。这意味着一个表中的...
    编程 发布于2024-11-08
  • 如何在 CSS 中缩进后续换行标签行?
    如何在 CSS 中缩进后续换行标签行?
    缩进换行标签文本的后续行当面临表单宽度的限制时,标签文本可以换行到多行,从而美观的担忧。虽然第一行由于输入元素的存在而缩进,但后续行可能不会缩进,从而产生不均匀的外观。要仅使用 CSS 实现缩进的第二行和后续行,请考虑使用以下方法:将输入元素及其标签包含在具有类 “checkbox-field” 的...
    编程 发布于2024-11-08
  • 掌握 CSS 中的 box-shadow:快速指南
    掌握 CSS 中的 box-shadow:快速指南
    CSS 中的 box-shadow 属性是开发人员向 HTML 元素引入深度和维度的有效机制。通过将阴影合并到元素中,可以增强用户界面的真实感和视觉吸引力。本文将深入探讨 box-shadow 的基础知识,并提供示例来帮助您掌握其应用。 了解基础知识 box-shadow 属性由几...
    编程 发布于2024-11-08
  • 冒烟测试:快速高效的质量检查
    冒烟测试:快速高效的质量检查
    冒烟测试是软件测试中至关重要的初始阶段,旨在快速识别可能阻止进一步测试或开发的关键缺陷。它充当安全网,确保软件在投入大量资源进行更全面的测试工作之前处于稳定状态。 了解冒烟测试 冒烟测试是一种高级测试套件,用于验证软件应用程序的基本功能。它专注于核心功能,并确保应用程序可以启动、导航和使用,而不会...
    编程 发布于2024-11-08
  • 避免代码中的错误:Moment.js 中的变异方法与非变异方法
    避免代码中的错误:Moment.js 中的变异方法与非变异方法
    使用 Moment.js 时,必须了解哪些方法更改原始日期对象以及哪些方法返回新值。这可以帮助您避免代码中出现意外的副作用。这是一个快速指南: ?改变原始日期对象的方法: startOf(unit) — 将日期设置为指定单位的开始日期(例如,“年”、“月”、“日”)。 endOf(unit) — 将...
    编程 发布于2024-11-08
  • SQL 中的反引号与单引号:主要区别是什么以及何时应该使用它们?
    SQL 中的反引号与单引号:主要区别是什么以及何时应该使用它们?
    SQL 查询中的反引号与单引号在 CodeIgniter 手册摘录中,提到 $this->db->select () 方法接受可选的第二个参数以禁用字段和表名称的反引号保护。这就提出了三个问题:1。反引号(`)和单引号(')有什么区别?MySQL中反引号引用名称,而单引号括住字符串。使用不带...
    编程 发布于2024-11-08
  • MLP-混合器(理论)
    MLP-混合器(理论)
    TL;DR - This is the first article I am writing to report on my journey studying the MPL-Mixer architecture. It will cover the basics up to an intermed...
    编程 发布于2024-11-08
  • 为什么需要类型保护?探索不同类型及其用例
    为什么需要类型保护?探索不同类型及其用例
    为什么需要类型保护?探索不同类型及其用例 在 TypeScript 中,类型保护在使代码库更加可靠、对开发人员更友好方面发挥着重要作用。它们通过允许开发人员缩小类型来帮助确保类型安全,这有助于减少运行时错误并使代码更易于理解和维护。 什么是类型保护? 类型保护是对类型执行运行时检查的函数表达式,确保...
    编程 发布于2024-11-08
  • 如何在 CSS 中将 Div 居中
    如何在 CSS 中将 Div 居中
    弹性盒: .container { display: flex; justify-content: center; align-items: center; height: 300px; } 网格 .container { display: gr...
    编程 发布于2024-11-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3