কম্পিউটার

গ্রেট সার্কেল দূরত্ব সূত্র ব্যবহার করে কাছাকাছি ক্যাব খুঁজে পেতে C++ প্রোগ্রাম


এই নিবন্ধে, আমরা গ্রেট সার্কেল দূরত্ব সূত্র ব্যবহার করে প্রায় (৫০ কিলোমিটারের কম) কাছাকাছি ক্যাবগুলি খুঁজে বের করার একটি প্রোগ্রাম নিয়ে আলোচনা করব৷

ধরুন আমাদেরকে একটি JSON ফাইল দেওয়া হয়েছে যেটিতে যাদের একটি ক্যাবের প্রয়োজন তাদের নাম এবং স্থানাঙ্ক এবং এছাড়াও উপলব্ধ সমস্ত ক্যাবের স্থানাঙ্ক রয়েছে৷

এটি সমাধান করার জন্য, আমরা জিপিএস স্থানাঙ্কগুলিকে দ্বিগুণে রূপান্তর করব। ডবল ফর্ম থেকে, আমরা অবশেষে তাদের ডিগ্রী রেডিয়ানে রূপান্তর করব। তারপর আমরা শেষ পর্যন্ত ব্যবহারকারীর অবস্থান থেকে 50 কিলোমিটারের মধ্যে উপলব্ধ ক্যাবগুলি খুঁজে পেতে গ্রেট সার্কেল দূরত্ব সূত্র প্রয়োগ করতে পারি।

মনে রাখবেন যে প্রচুর পরিমাণে ইনপুট ডেটার কারণে, আমরা JSON ফাইলটিকে প্রোগ্রামে ইনপুট হিসাবে গ্রহণ করব এবং অন্য JSON ফাইলেও আউটপুট দেব।

উদাহরণ

#include <bits/stdc++.h>
using namespace std;
#define pi 3.14159265358979323
#define earth_radius 6371.0
//defining the user's coordinates
#define latitude1d 12.9611159
#define longitude1d 77.6362214
ifstream users ("input.access_file");
ofstream out ("output.access_file");
//converting degree to radian
double to_radian(double degree) {
   return ( degree * (pi/180));
}
//to calculate the distance
double cal_distance(double latitude2d, double longitude2d) {
   double lat1, lon1, lat2, lon2, diff_lon, great_circle;
   lat1 = to_radian(latitude1d);
   lon1 = to_radian(longitude1d);
   lat2 = to_radian(latitude2d);
   lon2 = to_radian(longitude2d);
   diff_lon = lon2 - lon1;
   great_circle = acos( sin(lat1) * sin(lat2) + cos(lat1) *cos(lat2) * cos(diff_lon) );
   return (earth_radius * great_circle);
}
//creating structure to access JSON file
struct access_file {
   long long int user_length, i, j, x, y, m, n, f, friends,id[100000];
   char latitude_string[1000], longitude_string[1000], id_string[1000], name[1000];
   double latitude2d, longitude2d;
   string line;
   //to check the value of distance
   void check_distance() {
      if (cal_distance(latitude2d, longitude2d) <=50.0000) {
         id[i] = atoll(id_string);
         i++;
         out << "{\"User_id\": " << id[i - 1] << ", \"Name\": " << name << "}" << endl;
      }
   }
   void file_parser() {
      if (users.is_open()) {
         while (getline(users, line)) {
            f = 0; x = 0; y = 0; friends = 0; m = 0, n = 0;
            user_length = line.size();
            for (j = 0; j < user_length; j++) {
               if (line[j] == '"')
                  f++;
               else if (line[j] == ':')
                  friends++;
               if (f == 3) {
                  j++;
                  while (line[j] != '"') {
                     latitude_string[x] = line[j];
                     x++; j++;
                  }
                  j--; latitude_string[x] = '\0';
               }
               else if (f == 13) {
                  j++;
                  while (line[j] != '"') {
                     longitude_string[y] = line[j];
                     y++; j++;
                  }
                  j--; longitude_string[y] = '\0';
               }
               if (friends == 2) {
                  j += 2;
                  while (line[j] != ',') {
                     id_string[m] = line[j];
                     m++; j++;
                  }
                  j--; id_string[m] = '\0';
                  friends++;
               }
               else if (friends == 4) {
                  j += 2;
                  while (line[j] != ',') {
                     name[n] = line[j];
                     n++; j++;
                  }
                  j--; name[n] = '\0';
                  friends++; f += 2;
               }
            }
            //converting string to float
            latitude2d = atof(latitude_string);
            longitude2d = atof(longitude_string);
            check_distance();
         }
      }
      //closing input file
      users.close();
      //closing output file
      out.close();
   }
};
int main() {
   access_file object;
   object.file_parser();
   return 0;
}

আউটপুট

(A file named output.json will be created at the same place where the code and the input.json file is stored.)

  1. C++ ব্যবহার করে উপবৃত্তের ক্ষেত্রফল বের করার জন্য প্রোগ্রাম

  2. রিকারশন ব্যবহার করে G.C.D খুঁজে পেতে C++ প্রোগ্রাম

  3. LCM খুঁজে পেতে C++ প্রোগ্রাম

  4. GCD খুঁজে পেতে C++ প্রোগ্রাম