summaryrefslogtreecommitdiff
path: root/sem_2/HLIN202/TP/TP11-12/exo6.cpp
blob: 55b5d4d320356fcb9a52611e14f036d3509b9604 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
#include<iostream>
#include<cmath>


struct s_point {
  char nom;
  int x,y;
};

struct lignepolygonale {
  int nombre;
  s_point *points;
};

double distance (s_point, s_point);
void affiche (s_point);

double longueur ( lignepolygonale lp) {
  double ret=0;
  for ( int i = 0; i < lp.nombre-1; i ++) {
    ret += distance (lp.points[i], lp.points[i+1]);
  }
  return ret;
}
lignepolygonale saisieLP () {
  lignepolygonale ret;
  std::cout<<"Nombre de points de la LP :";
  std::cin>>ret.nombre;
  std::cout<<std::endl;
  ret.points=new s_point[ret.nombre];
  for ( int i =0; i < ret.nombre; i ++) {
    std::cout<< " Entrez le nom du point numero "<<i+1<<" ";
    std::cin >> ret.points[i].nom;
    std::cout << " Entrez les coords du point " << ret.points[i].nom << std::endl<<"x : ";
    std::cin >> ret.points[i].x;
    std::cout<<"    y : ";
    std::cin>>ret.points[i].y;
    std::cout<<std::endl;
  }
  return ret;
}
lignepolygonale carre ( int n, s_point A) {
  lignepolygonale ret;
  ret.nombre=5;
  ret.points=new s_point[ret.nombre];
  ret.points[0]=A;
  ret.points[1].x=A.x+n;
  ret.points[1].y=A.y;
  ret.points[2].x=A.x+n;
  ret.points[2].y=A.y+n;
  ret.points[3].x=A.x;
  ret.points[3].y=A.y+n;
  ret.points[4]=A;
  return ret;
}
void afficheLP ( lignepolygonale lp){
  for (int i = 0; i< lp.nombre; i ++){
    affiche(lp.points[i]);
  }
}
double distance (s_point a, s_point b){
  return sqrt(pow(b.x-a.x,2)+pow(b.y-a.y,2));
}

s_point saisie (){
  s_point point;
  std::cout<<"Saisir le nom du point ( une lettre capitale) "<<std::endl;
  std::cin>>point.nom;
  std::cout<<std::endl<<"Saisir la coordonnee en x ";
  std::cin >>point.x;
  std::cout << std::endl << "Saisir la coordonnee en y ";
  std::cin >> point.y;
  std::cout << std::endl;
  if ( (int) point.nom > 90 || (int)point.nom < 65){
    std::cout<<" Saisie incorrecte"<<std::endl;
    point = saisie();}
  return point;
}
void affiche (s_point point){
  std::cout<<"point"<<point.nom<<" de coordonees " << point.x << point.y << std::endl;
}
void maz ( s_point * point) {
  point->nom = (char)0;
  point->x=0;
  point->y=0;
}
s_point sym ( s_point point) {
  s_point ret;
  ret.x= - point.x;
  ret.y= -point.y;
  ret.nom = (char)(65+(90-(int)point.nom));
  return ret;
}
int main () {
  lignepolygonale zbeb;
  zbeb=saisieLP();
  return 0;
}