Number of White Cells: Nurikabe logical game (sometimes called Islands in the Stream) is a binary determination puzzle. The puzzle is played on a typically rectangular grid of cells, some of which contain numbers. You must decide for each cell if it is white or black (by clicking on them) according to the following rules:
- All of the black cells must be connected.
- Each numbered cell must be part of a white island of connected white cells.
- Each island must have the same number of white cells as the number it contains (including the numbered cell).
- Two islands may not be connected.
- There cannot be any 2×2 blocks of black cells.
Unnumbered cells start out grey and cycle through white and black when clicked. Initially numbered cells are white in color.
Problem Statement:
Write a program to find the number of white cells in the final configuration of the board, given a valid initial configuration. Below figure is the sample valid initial configuration.
![[Solved] Number of White Cells with Java, C++ [Solved] Number of White Cells with Java, C++](https://app.e-box.co.in/uploads/Image/nurikabe1.png)
Input Format:
First line of the input is an integer N that gives the number of rows and columns of the grid.
Next N lines will have a valid initial board configuration with N*N cells. Assume that the maximum number in a cell can be 10. Grey colored cells are represented by the integer 20 in the matrix representation of the input configuration.
Output Format:
Output should display an integer that the number of white cells in the final configuration of the board.
Refer sample input and output for formatting specifications.
Sample Input 1:
5
20 20 1 20 3
20 20 20 20 20
20 20 20 20 20
20 20 20 20 20
6 20 3 20 20
Sample Output 1:
13
Sample Input 2:
5
20 20 20 20 20
3 20 20 6 20
20 20 20 20 20
20 2 20 20 1
20 20 20 20 20
Sample Output 2:
12
Solution
import java.util.Scanner;
public class Main
{
    public static void main(String[] args)
    {
        Scanner sc=new Scanner(System.in);
        int i,j,n,sum=0;
        int[][] a=new int[50][50];
        n=sc.nextInt();
        for(i=0;i<n;i++)
        {
            for(j=0;j<n;j++)
            {
                //sauravhathi
                a[i][j]=sc.nextInt();
            }
        }
        for(i=0;i<n;i++)
        {
            for(j=0;j<n;j++)
            {
                //sauravhathi
                if(a[i][j]!=20)
                sum+=a[i][j];
            }
        }
        System.out.println(sum);
    }
}#include <iostream>
using namespace std;
int main()
{
    int n, i, j, sum = 0;
    cin >> n;
    int a[n][n];
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            //sauravhathi
            cin >> a[i][j];
        }
    }
    for (i = 0; i < n; i++)
    {
        for (j = 0; j < n; j++)
        {
            //sauravhathi
            if (a[i][j] != 20)
                sum += a[i][j];
        }
    }
    cout << sum;
    return 0;
}
Happy Learning – If you require any further information, feel free to contact me.
![[Solved] Number of White Cells with Java, C++ [Solved] Number of White Cells with Java, C++](https://realcoder.techss24.com/wp-content/uploads/2022/07/Solved-Number-of-White-Cells-with-Java-C.png)
![[Solved] You are given two strings str1 and str2. Find the minimum number of edits (operations) that can be performed on str1 to transform it into str2 with Java](https://realcoder.techss24.com/wp-content/uploads/2022/08/Solved-You-are-given-two-strings-str1-and-str2.-Find-the-minimum-number-of-edits-operations-that-can-be-performed-on-str1-to-transform-it-into-str2-with-Java-300x200.png)
![[Solved] A company is transmitting data to another server Security key](https://realcoder.techss24.com/wp-content/uploads/2023/08/Solved-A-company-is-transmitting-data-to-another-server-Security-key-300x169.png)
![[Solved] Command Line Argument Print String or Integer with Java, C++](https://realcoder.techss24.com/wp-content/uploads/2022/07/Solved-Command-Line-Argument-Print-String-or-Integer-with-Java-C-300x200.png)