Computer >> कंप्यूटर >  >> प्रोग्रामिंग >> C++

जाँच करें कि क्या कोई राजा एक वैध चाल चल सकता है या नहीं जब N रातें C++ में एक संशोधित शतरंज की बिसात में हों

अवधारणा

दिए गए अनंत बिसात के संबंध में शतरंज के समान नियमों के साथ और दिए गए N शूरवीरों को अनंत शतरंज की बिसात पर निर्देशांक (-10^9 <=x, y <=10^9) और राजा का समन्वय, कार्य यह सत्यापित करना है कि क्या राजा चेकमेट है या नहीं।

इनपुट

a1[] = { { 2, 1 }, { 1, 3 }, { 3, 6 },{ 5, 5 }, { 6, 1 }, { 7, 3 }} king -> {4, 3}

आउटपुट

Yes

चेक मेट होने के कारण राजा कोई चाल नहीं चल पा रहा है।

इनपुट

a1 [] = {{1, 1}} king -> {3, 4}

आउटपुट

No

राजा वैध चाल चलने में सक्षम हो सकता है।

विधि

यहाँ, शतरंज के टुकड़ों के बीच नाइट की चाल असामान्य है। इसकी गति एक वर्ग की ओर होती है जो क्षैतिज रूप से दो वर्ग दूर और एक वर्ग लंबवत, या दो वर्ग लंबवत और एक वर्ग क्षैतिज रूप से होता है। तो, पूरी चाल हर संभव आकार (8 संभावित चाल) में "एल" अक्षर की तरह दिखती है। इसके परिणामस्वरूप, सभी संभावित निर्देशांकों को चिह्नित करने के लिए जोड़े के हैश मैप को लागू करें जहां नाइट चल सकता है। यदि यह देखा गया है कि राजा अपने आस-पास के 8 निर्देशांकों में से किसी पर भी नहीं जा सकता है, अर्थात, यदि समन्वय को एक शूरवीर की चाल से धोया जाता है, तो इसे "चेकमेट" घोषित किया जाता है।

उदाहरण

// C++ program for verifying if a king
// can move a valid move or not when
// N nights are there in a modified chessboard
#include <bits/stdc++.h>
using namespace std;
bool checkCheckMate1(pair<int, int>a1[], int n1, int kx1, int ky1){
   // Pair of hash to indicate or mark the coordinates
   map<pair<int, int>, int> mpp1;
   // iterate for Given N knights
   for (int i = 0; i < n1; i++) {
      int x = a1[i].first;
      int y = a1[i].second;
      // indicate or mark all the "L" shaped coordinates
      // that can be reached by a Knight
      // starting or initial position
      mpp1[{ x, y }] = 1;
      // 1-st move
      mpp1[{ x - 2, y + 1 }] = 1;
      // 2-nd move
      mpp1[{ x - 2, y - 1 }] = 1;
      // 3-rd move
      mpp1[{ x + 1, y + 2 }] = 1;
      // 4-th move
      mpp1[{ x + 1, y - 2 }] = 1;
      // 5-th move
      mpp1[{ x - 1, y + 2 }] = 1;
      // 6-th move
      mpp1[{ x + 2, y + 1 }] = 1;
      // 7-th move
      mpp1[{ x + 2, y - 1 }] = 1;
      // 8-th move
      mpp1[{ x - 1, y - 2 }] = 1;
   }
   // iterate for all possible 8 coordinates
   for (int i = -1; i < 2; i++) {
      for (int j = -1; j < 2; j++) {
         int nx = kx1 + i;
         int ny = ky1 + j;
         if (i != 0 && j != 0) {
            // verify or check a move can be made or not
            if (!mpp1[{ nx, ny }]) {
               return true;
            }
         }
      }
   }
   // any moves
   return false;
}
// Driver Code
int main(){
   pair<int, int&lgt; a1[] = { { 2, 1 }, { 1, 3 }, { 3, 6 }, { 5, 5 }, { 6, 1 }, { 7, 3 }};
   int n1 = sizeof(a1) / sizeof(a1[0]);
   int x = 4, y = 3;
   if (checkCheckMate1(a1, n1, x, y))
      cout << "Not Checkmate!";
   else
      cout << "Yes its checkmate!";
   return 0;
}

आउटपुट

Yes its checkmate!

  1. n आकार के दिए गए सरणी की जाँच करें n स्तरों के BST का प्रतिनिधित्व कर सकते हैं या C++ में नहीं

    हमारे पास एक सरणी ए है, हमें यह जांचना होगा कि सरणी एन स्तरों के साथ बीएसटी का प्रतिनिधित्व कर सकती है या नहीं। जैसा कि स्तर है, हम निम्नलिखित तरीके से एक पेड़ का निर्माण कर सकते हैं। मान लें कि कोई संख्या k है, k से बड़ा मान दाईं ओर जाता है, और k से कम बाईं ओर चलता है। मान लीजिए कि दो सूचियाँ हैं:{

  1. जांचें कि कोई संख्या कृष्णमूर्ति संख्या है या नहीं C++

    यहां हम देखेंगे कि किसी संख्या की जांच कैसे करें कृष्णमूर्ति संख्या है या नहीं। एक संख्या कृष्णमूर्ति संख्या होती है, यदि प्रत्येक अंक के भाज्य का योग संख्या के समान हो। उदाहरण के लिए, यदि कोई संख्या 145 है, तो योग =1! +4! +5! =1 + 24 + 120 =145। तो यह कृष्णमूर्ति संख्या है, तर्क सरल है, हमें प्रत्

  1. जाँच करें कि क्या कोई राजा एक वैध चाल चल सकता है या नहीं जब पायथन में एक संशोधित शतरंज की बिसात में N रातें होती हैं

    मान लीजिए कि हमारे पास शतरंज के समान नियमों के साथ एक अनंत शतरंज की बिसात है और अगर अनंत शतरंज की बिसात पर N शूरवीर निर्देशांक हैं और राजा का समन्वय है, तो हमें यह जांचना होगा कि राजा चेकमेट है या नहीं। अनंत बोर्ड का निर्देशांक बड़े मान से घिरा होता है जैसे (-10^9 <=x, y <=10^9)। तो, अगर इनपुट शूरव