Konoha

Finished
44//
55
66/**
7 * @param {string[]} input
8 * @returns {string[]}
7 * Annotates a flower field by replacing empty spaces with the count of adjacent flowers.
8 * @param {string[]} input - Array of strings representing the flower field
9 * @returns {string[]} - Array of strings with annotations added
910 */
1011export const annotate = (input) => {
11 throw new Error('Remove this statement and implement this function');
12 // Edge Case: Handle empty input
13 if (!input || input.length === 0) {
14 return [];
15 }
16
17 // Edge Case: Handle input with empty strings
18 const rows = input.length;
19 const cols = input[0].length;
20
21 // Edge Case: Handle rows with different lengths
22 for (let i = 0; i < rows; i++) {
23 if (input[i].length !== cols) {
24 throw new Error('All rows must have the same length');
25 }
26 }
27
28 // Create a 2D array for easier manipulation
29 const field = input.map(row => row.split(''));
30 const result = Array(rows).fill().map(() => Array(cols).fill(''));
31
32 // Define the 8 possible directions (horizontal, vertical, diagonal)
33 const directions = [
34 [-1, -1], [-1, 0], [-1, 1],
35 [0, -1], [0, 1],
36 [1, -1], [1, 0], [1, 1]
37 ];
38
39 // Process each cell
40 for (let i = 0; i < rows; i++) {
41 for (let j = 0; j < cols; j++) {
42 // If it's a flower, keep it as is
43 if (field[i][j] === '*') {
44 result[i][j] = '*';
45 } else {
46 // Count adjacent flowers
47 let count = 0;
48
49 // Check all 8 directions
50 for (const [dx, dy] of directions) {
51 const ni = i + dx;
52 const nj = j + dy;
53
54 // Edge Case: Check bounds to avoid accessing invalid indices
55 if (ni >= 0 && ni < rows && nj >= 0 && nj < cols) {
56 if (field[ni][nj] === '*') {
57 count++;
58 }
59 }
60 }
61
62 // Edge Case: If no adjacent flowers, leave the cell empty
63 result[i][j] = count === 0 ? ' ' : count.toString();
64 }
65 }
66 }
67
68 // Convert back to array of strings
69 return result.map(row => row.join(''));
1270};
71
72// Handled Edge Cases: Empty input, input with empty strings, rows with different lengths, out-of-bounds access, cells with no adjacent flowers
Test NameStatus
handles no rows
Pass
handles no columns
Pass
handles no flowers
Pass
handles garden full of flowers
Pass
handles flower surrounded by spaces
Pass
handles space surrounded by flowers
Pass
handles horizontal line
Pass
handles horizontal line, flowers at edges
Pass
handles vertical line
Pass
handles vertical line, flowers at edges
Pass
handles cross
Pass
handles large garden
Pass

© 2025 Ridges AI. Building the future of decentralized AI development.