* fix: remove isHidden flag from frontmatter * fix: add isUpcomingChange Co-authored-by: Ahmad Abdolsaheb <ahmad.abdolsaheb@gmail.com> * feat: hide blocks not challenges Co-authored-by: Ahmad Abdolsaheb <ahmad.abdolsaheb@gmail.com> Co-authored-by: Ahmad Abdolsaheb <ahmad.abdolsaheb@gmail.com>
87 lines
3.1 KiB
Markdown
87 lines
3.1 KiB
Markdown
---
|
|
id: 587d7dbb367417b2b2512baa
|
|
title: Reuse Patterns Using Capture Groups
|
|
challengeType: 1
|
|
forumTopicId: 301364
|
|
---
|
|
|
|
## Description
|
|
<section id='description'>
|
|
Some patterns you search for will occur multiple times in a string. It is wasteful to manually repeat that regex. There is a better way to specify when you have multiple repeat substrings in your string.
|
|
You can search for repeat substrings using <dfn>capture groups</dfn>. Parentheses, <code>(</code> and <code>)</code>, are used to find repeat substrings. You put the regex of the pattern that will repeat in between the parentheses.
|
|
To specify where that repeat string will appear, you use a backslash (<code>\</code>) and then a number. This number starts at 1 and increases with each additional capture group you use. An example would be <code>\1</code> to match the first group.
|
|
The example below matches any word that occurs twice separated by a space:
|
|
|
|
```js
|
|
let repeatStr = "regex regex";
|
|
let repeatRegex = /(\w+)\s\1/;
|
|
repeatRegex.test(repeatStr); // Returns true
|
|
repeatStr.match(repeatRegex); // Returns ["regex regex", "regex"]
|
|
```
|
|
|
|
Using the <code>.match()</code> method on a string will return an array with the string it matches, along with its capture group.
|
|
</section>
|
|
|
|
## Instructions
|
|
<section id='instructions'>
|
|
Use capture groups in <code>reRegex</code> to match numbers that are repeated only three times in a string, each separated by a space.
|
|
</section>
|
|
|
|
## Tests
|
|
<section id='tests'>
|
|
|
|
```yml
|
|
tests:
|
|
- text: Your regex should use the shorthand character class for digits.
|
|
testString: assert(reRegex.source.match(/\\d/));
|
|
- text: Your regex should reuse a capture group twice.
|
|
testString: assert(reRegex.source.match(/\\1|\\2/g).length >= 2);
|
|
- text: Your regex should have two spaces separating the three numbers.
|
|
testString: assert(reRegex.source.match(/ |\\s/g).length === 2 || reRegex.source.match(/\(\\s\)(?=.*\\(1|2))/g));
|
|
- text: Your regex should match <code>"42 42 42"</code>.
|
|
testString: assert(reRegex.test("42 42 42"));
|
|
- text: Your regex should match <code>"100 100 100"</code>.
|
|
testString: assert(reRegex.test("100 100 100"));
|
|
- text: Your regex should not match <code>"42 42 42 42"</code>.
|
|
testString: assert.equal(("42 42 42 42").match(reRegex.source), null);
|
|
- text: Your regex should not match <code>"42 42"</code>.
|
|
testString: assert.equal(("42 42").match(reRegex.source), null);
|
|
- text: Your regex should not match <code>"101 102 103"</code>.
|
|
testString: assert(!reRegex.test("101 102 103"));
|
|
- text: Your regex should not match <code>"1 2 3"</code>.
|
|
testString: assert(!reRegex.test("1 2 3"));
|
|
- text: Your regex should match <code>"10 10 10"</code>.
|
|
testString: assert(reRegex.test("10 10 10"));
|
|
|
|
```
|
|
|
|
</section>
|
|
|
|
## Challenge Seed
|
|
<section id='challengeSeed'>
|
|
|
|
<div id='js-seed'>
|
|
|
|
```js
|
|
let repeatNum = "42 42 42";
|
|
let reRegex = /change/; // Change this line
|
|
let result = reRegex.test(repeatNum);
|
|
```
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</section>
|
|
|
|
## Solution
|
|
<section id='solution'>
|
|
|
|
```js
|
|
let repeatNum = "42 42 42";
|
|
let reRegex = /^(\d+)\s\1\s\1$/;
|
|
let result = reRegex.test(repeatNum);
|
|
```
|
|
|
|
</section>
|