Table of Contents
Solution
Example
Output
Home Backend Development C++ Find the number of points that have at least one point above, below, left or right of it in C++

Find the number of points that have at least one point above, below, left or right of it in C++

Sep 05, 2023 am 08:57 AM
c language programming Number of point neighbors

Find the number of points that have at least one point above, below, left or right of it in C++

In this problem, we are given N points located on a 2D plane. Our task is to find the number of points that have at least 1 point above, below, to the left or to the right of it.

We need to calculate all points that have at least 1 point 1 point that satisfies any of the following conditions.

The point above it− The point will have the same X coordinate and a Y coordinate 1 greater than its current value. p>

The point below it− The point will have the same X coordinate and a Y coordinate 1 less than its current value.

The point to its left− The point will have the same Y coordinate and an X coordinate 1 less than its current value.

Point to the right of this point − This point will have the same Y coordinate and X coordinate 1 greater than the current value.

Let us take an example to understand this problem,

Input : arr[] = {{1, 1}, {1, 0}, {0, 1}, {1, 2}, {2, 1}}
Output :1
Copy after login

Solution

In order to solve this problem, we need to take out each point and find the maximum and minimum values ​​of X and Y coordinates that its neighboring points can have for valid counting. If there are any coordinates with the same X coordinate and a Y value within that range. We will add points. We store the count in a variable and return it.

Example

Let us take an example to understand the problem

#include <bits/stdc++.h>
using namespace std;
#define MX 2001
#define OFF 1000
struct point {
   int x, y;
};
int findPointCount(int n, struct point points[]){
   int minX[MX];
   int minY[MX];
   int maxX[MX] = { 0 };
   int maxY[MX] = { 0 };
   int xCoor, yCoor;
   fill(minX, minX + MX, INT_MAX);
   fill(minY, minY + MX, INT_MAX);
   for (int i = 0; i < n; i++) {
      points[i].x += OFF;
      points[i].y += OFF;
      xCoor = points[i].x;
      yCoor = points[i].y;
      minX[yCoor] = min(minX[yCoor], xCoor);
      maxX[yCoor] = max(maxX[yCoor], xCoor);
      minY[xCoor] = min(minY[xCoor], yCoor);
      maxY[xCoor] = max(maxY[xCoor], yCoor);
   }
   int pointCount = 0;
   for (int i = 0; i < n; i++) {
      xCoor = points[i].x;
      yCoor = points[i].y;
      if (xCoor > minX[yCoor] && xCoor < maxX[yCoor])
         if (yCoor > minY[xCoor] && yCoor < maxY[xCoor])
            pointCount++;
   }
   return pointCount;
}
int main(){
   struct point points[] = {{1, 1}, {1, 0}, {0, 1}, {1, 2}, {2, 1}};
   int n = sizeof(points) / sizeof(points[0]);
   cout<<"The number of points that have atleast one point above, below, left, right is "<<findPointCount(n, points);
}
Copy after login

Output

The number of points that have atleast one point above, below, left, right is 1
Copy after login

The above is the detailed content of Find the number of points that have at least one point above, below, left or right of it in C++. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Recommend five practical C language programming software Recommend five practical C language programming software Feb 18, 2024 pm 09:51 PM

As a widely used programming language, C language has always been loved by developers. When programming in C language, it is very important to choose appropriate programming software. This article will take stock of five practical C language programming tools to help you improve programming efficiency and development quality. VisualStudioCode (VSCode) VisualStudioCode is a lightweight cross-platform code editor with a powerful plug-in ecosystem that supports multiple languages ​​and frameworks. VS

Essential software for C language programming: five good helpers recommended for beginners Essential software for C language programming: five good helpers recommended for beginners Feb 20, 2024 pm 08:18 PM

C language is a basic and important programming language. For beginners, it is very important to choose appropriate programming software. There are many different C programming software options on the market, but for beginners, it can be a bit confusing to choose which one is right for you. This article will recommend five C language programming software to beginners to help them get started quickly and improve their programming skills. Dev-C++Dev-C++ is a free and open source integrated development environment (IDE), especially suitable for beginners. It is simple and easy to use, integrating editor,

How to implement Chinese input and output in C language program? How to implement Chinese input and output in C language program? Feb 19, 2024 pm 08:22 PM

How to handle Chinese input and output in C language programming software? With the further development of globalization, the application scope of Chinese is becoming more and more extensive. In C language programming, if you need to process Chinese input and output, you need to consider the encoding of Chinese characters and related processing methods. This article will introduce some common methods for processing Chinese input and output in C language programming software. First, we need to understand how Chinese characters are encoded. In computers, the most commonly used Chinese character encoding method is Unicode encoding. Unicode encoding can represent

Five programming software for getting started with learning C language Five programming software for getting started with learning C language Feb 19, 2024 pm 04:51 PM

As a widely used programming language, C language is one of the basic languages ​​that must be learned for those who want to engage in computer programming. However, for beginners, learning a new programming language can be difficult, especially due to the lack of relevant learning tools and teaching materials. In this article, I will introduce five programming software to help beginners get started with C language and help you get started quickly. The first programming software was Code::Blocks. Code::Blocks is a free, open source integrated development environment (IDE) for

How to sort Chinese characters in C language environment? How to sort Chinese characters in C language environment? Feb 18, 2024 pm 02:10 PM

How to implement Chinese character sorting function in C language programming software? In modern society, the Chinese character sorting function is one of the essential functions in many software. Whether in word processing software, search engines or database systems, Chinese characters need to be sorted to better display and process Chinese text data. In C language programming, how to implement the Chinese character sorting function? One method is briefly introduced below. First of all, in order to implement the Chinese character sorting function in C language, we need to use the string comparison function. Ran

Analyze common input format issues of C language scanf function Analyze common input format issues of C language scanf function Feb 19, 2024 am 09:30 AM

Analysis of Frequently Asked Questions about C Language Scanf Input Format In the process of programming in C language, the input function is very important for the running of the program. We often use the scanf function to receive user input. However, due to the diversity and complexity of the input, some common problems may arise when using the scanf function. This article will analyze some common scanf input format issues and provide specific code examples. The input characters do not match the format. When using the scanf function, we need to specify the input format. For example, "%d

How to implement encoding and decoding of Chinese characters in C language programming? How to implement encoding and decoding of Chinese characters in C language programming? Feb 19, 2024 pm 02:15 PM

In modern computer programming, C language is one of the most commonly used programming languages. Although the C language itself does not directly support Chinese encoding and decoding, we can use some technologies and libraries to achieve this function. This article will introduce how to implement Chinese encoding and decoding in C language programming software. First, to implement Chinese encoding and decoding, we need to understand the basic concepts of Chinese encoding. Currently, the most commonly used Chinese encoding scheme is Unicode encoding. Unicode encoding assigns a unique numeric value to each character so that when calculating

How to manage a complete circular queue of events in C++? How to manage a complete circular queue of events in C++? Sep 04, 2023 pm 06:41 PM

Introduction CircularQueue is an improvement on linear queues, which was introduced to solve the problem of memory waste in linear queues. Circular queues use the FIFO principle to insert and delete elements from it. In this tutorial, we will discuss the operation of a circular queue and how to manage it. What is a circular queue? Circular queue is another type of queue in data structure where the front end and back end are connected to each other. It is also known as circular buffer. It operates similarly to a linear queue, so why do we need to introduce a new queue in the data structure? When using a linear queue, when the queue reaches its maximum limit, there may be some memory space before the tail pointer. This results in memory loss, and a good algorithm should be able to make full use of resources. In order to solve the waste of memory

See all articles