freeCodeCamp/curriculum/challenges/chinese/02-javascript-algorithms-an.../regular-expressions/find-one-or-more-criminals-...

2.5 KiB
Raw Blame History

id title challengeType forumTopicId dashedName
587d7db7367417b2b2512b9c 在狩猎中找到一个或多个罪犯 1 301343 find-one-or-more-criminals-in-a-hunt

--description--

是时候停一停来测试你的正则表达式使用能力了。 一群罪犯越狱逃跑了,但你不知道有多少人。 然而,你知道他们不在一起时会保持紧密联系。 你有责任立刻找到所有的罪犯。

这里有一个示例来提示如何做到这一点:

当字母z在一行中出现一次或连续多次时,正则表达式/z+/会匹配到它。 它会在以下所有字符串中找到匹配项:

"z"
"zzzzzz"
"ABCzzzz"
"zzzzABC"
"abczzzzzzzzzzzzzzzzzzzzzabc"

但是它不会在以下字符串中找到匹配项,因为它们中没有字母z

""
"ABC"
"abcabc"

--instructions--

编写一个贪婪正则表达式,在一组其他人中匹配到一个或多个罪犯。 罪犯由大写字母C表示。

--hints--

您的正则表达式应该匹配字符串 C 中的一个罪犯(C)

assert('C'.match(reCriminals) && 'C'.match(reCriminals)[0] == 'C');

您的正则表达式应该匹配字符串 CC 中的两个罪犯(CC)

assert('CC'.match(reCriminals) && 'CC'.match(reCriminals)[0] == 'CC');

您的正则表达式应该在字符串 P1P5P4CCCcP2P6P3 中匹配三个罪犯(CCC)。

assert(
  'P1P5P4CCCcP2P6P3'.match(reCriminals) &&
    'P1P5P4CCCcP2P6P3'.match(reCriminals)[0] == 'CCC'
);

您的正则表达式应该在字符串 P6P2P7P4P5CCCCCP3P1中匹配五个罪犯(CCCCC)

assert(
  'P6P2P7P4P5CCCCCP3P1'.match(reCriminals) &&
    'P6P2P7P4P5CCCCCP3P1'.match(reCriminals)[0] == 'CCCCC'
);

你的正则表达式在""中不应该匹配到任何罪犯

assert(!reCriminals.test(''));

你的正则表达式在P1P2P3中不应该匹配到任何罪犯

assert(!reCriminals.test('P1P2P3'));

你的正则表达式应该在P2P1P5P4CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCP3中匹配五十个 罪犯('CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC')。

assert(
  'P2P1P5P4CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCP3'.match(
    reCriminals
  ) &&
    'P2P1P5P4CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCP3'.match(
      reCriminals
    )[0] == 'CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC'
);

--seed--

--seed-contents--

let reCriminals = /./; // Change this line

--solutions--

let reCriminals = /C+/; // Change this line