神奇的字符串:JavaScript 中的问题

王林
풀어 주다: 2023-09-08 12:17:05
앞으로
925명이 탐색했습니다.

神奇的字符串:JavaScript 中的问题

问题

神奇的字符串 str 仅由 '1' 和 '2' 组成,并遵循以下规则 -

字符串 str 是神奇的,因为它连接了数字字符“1”和“2”连续出现生成字符串 str 本身。

字符串 str 的前几个元素如下 -

str = "1221121221221121122……"
로그인 후 복사

如果我们将 str 中连续的 '1' 和 '2' 分组,它将是 -

1 22 11 2 1 22 1 22 11 2 11 22 ......
로그인 후 복사

每组中“1”或“2”的出现次数为 -

1 2 2 1 1 2 1 2 2 1 2 2 ......
로그인 후 복사

我们可以看到上面的出现序列就是字符串本身。

我们给定一个整数num作为输入,我们需要返回字符串中第一个num中'1的个数。神奇的字符串str。

例如,如果函数的输入是 -

const num = 6;
로그인 후 복사

那么输出应该是 -

const output = 3;
로그인 후 복사

输出说明:

神奇字符串S的前6个元素是“12211”,其中包含三个1,因此返回3。

示例

其代码为 -

 现场演示

const num = 6;
const magicalString = (num = 1) => {
   let ind = 12;
   let str = '1221121221221121122';
   while(str.length < num){
      const end = str.substring(str.length - 1) === '2' ? '1' : '2';
      str = parseInt(str.substring(ind, ind + 1)) === 2 ? str + end + end : str + end;
      ind++;
   };
   return (str.substring(0, num).match(/1/g)||[]).length;
};
console.log(magicalString(num));
로그인 후 복사

输出

控制台中的输出将是 -

3
로그인 후 복사

위 내용은 神奇的字符串:JavaScript 中的问题의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:tutorialspoint.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!