Advertisement
Guest User

Untitled

a guest
May 19th, 2019
76
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.99 KB | None | 0 0
  1. #include <iostream>
  2. #include <string.h>
  3. #include <cstdlib>
  4. #include <algorithm>
  5.  
  6. using namespace std;
  7.  
  8. struct odcinek
  9. {
  10.     double x1, y1, x2, y2;
  11.     string nazwa;
  12.     int nr;
  13.     bool operator < (const odcinek &x)const
  14.     {
  15.         return x1>x.x1;
  16.     }
  17. };
  18.  
  19.  
  20. int main()
  21. {
  22.     int n;
  23.     cout << "Podaj liczbe odcinkow do wprowadzenia: "; cin >> n;
  24.     odcinek dane[n];
  25.  
  26.     for (int i=0; i<n; i++)
  27.     {
  28.         dane[i].nr = i+1;
  29.         cout <<"Podaj nazwe odcinka: "; cin>>dane[i].nazwa;
  30.         cout <<"Podaj x1: "; cin >>dane[i].x1;
  31.         cout <<"Podaj y1: "; cin >>dane[i].y1;
  32.         cout <<"Podaj x2: "; cin >>dane[i].x2;
  33.         cout <<"Podaj y2: "; cin >>dane[i].y2;
  34.  
  35.     }
  36.     for (int i=0; i<n; i++)
  37.     {
  38.         cout <<"Odcienk nr: "<<dane[i].nr;
  39.         cout <<" Nazywa sie: "<<dane[i].nazwa<<endl;
  40.         cout <<"Posiada x1: "<<dane[i].x1<<endl;
  41.         cout <<"Posiada y1: "<<dane[i].y1<<endl;
  42.         cout <<"Posiada x2: "<<dane[i].x2<<endl;
  43.         cout <<"Posiada y2: "<<dane[i].y2<<endl;
  44.  
  45.     }
  46.  
  47.     cout <<"Rozpoczynam sortowanie"<<endl<<endl;
  48.     sort (dane, dane+n);
  49.  
  50.     for (int i=0; i<n; i++)
  51.     {
  52.         cout <<"Odcienk nr: "<<dane[i].nr;
  53.         cout <<" Nazywa sie: "<<dane[i].nazwa<<endl;
  54.         cout <<"Posiada x1: "<<dane[i].x1<<endl;
  55.         cout <<"Posiada y1: "<<dane[i].y1<<endl;
  56.         cout <<"Posiada x2: "<<dane[i].x2<<endl;
  57.         cout <<"Posiada y2: "<<dane[i].y2<<endl;
  58.  
  59.     }
  60.  
  61.     cout <<endl<<endl<<endl;
  62.     cout <<"Wypisuje ktory odcinek z ktorym bede sprawdzal: "<<endl;
  63.  
  64.     for (int i=0; i<n; i++)
  65.     {
  66.          if ((min(dane[i].x1, dane[i].x2)<=dane[i+1].x1&&dane[i+1].x1<=max(dane[i].x1, dane[i].x2))
  67.             ||
  68.             (min(dane[i].x1, dane[i].x2)<=dane[i+1].x2&&dane[i+1].x2<=max(dane[i].x1, dane[i].x2)))
  69.             {
  70.                 cout <<"Odcinek : " << dane[i].nazwa << " zostanie poddany sprawdzeniu z odcinkiem: " <<dane[i+1].nazwa<<endl;
  71.             }
  72.     }
  73.  
  74.  
  75.     return 0;
  76. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement