Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Andrey619
1 / 1 / 0
Регистрация: 16.04.2013
Сообщений: 49
#1

Количество треугольников, лежащих в каждой координатной четверти - C++

19.11.2014, 22:38. Просмотров 233. Ответов 1
Метки нет (Все метки)

Пусть n треугольников заданы координатами своих вершин. Посчитайте количество треугольников, лежащих в каждой координатной четверти и не пересекающих оси координат.
(Использывать функцию для определения координатной четверти, в которой лежит треугольник).

(P.S: На экран выводится 4-и четверти, в каждой написано количество треугольников, лежащих в каждой координатной четверти и не пересекающих оси координат, увы с ошибками)

Программа в некоторых случаях не правильно считает количество треугольников. А точнее считает лишние, которые даже не вводились. Помогите пожалуйста исправить недочёты в программе.

C++
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
#include <iostream>
 
using namespace std;
 
int quarter(double x[], double y[]){
    
    if (x[0] * x[1] < 0 || x[0] * x[2] < 0 ||
         y[0] * y[1] < 0 || y[0] * y[2] < 0)
         return 0;
         
    if (x[0] < 0 || x[1] < 0 || x[2] < 0){
        if (y[0] < 0 || y[1] < 0 || y[2] < 0)
            return 3;
        else
            return 2;
    }else{
        if (y[0] < 0 || y[1] < 0 || y[2] < 0)
            return 4;
        else
            return 1;
    }
        
}
 
int main(){
   
   int n;
   cout << "n = ";cin >> n;
   
    int out[5] = {};
    for (int i = 1; i <= n; ++i){
        double x[3], y[3];
        for (int j = 1; j <= 3; ++j){
           cout << "x" << j << " = ";
           cin >> x[j - 1];
           cout << "y" << j << " = ";
           cin >> y[j - 1];
           ++out[quarter(x, y)];
       }
   }
   
   for (int i = 1; i <= 4; ++i)
      cout << out[i] << ' ';
      cout << endl;
   return 0;
}
1
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.11.2014, 22:38
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Количество треугольников, лежащих в каждой координатной четверти (C++):

Функции: посчитайте количество треугольников, лежащих в каждой координатной четверти и не пересекающих оси - C++
Пусть дано n треугольников. посчитайте количество треугольников, лежащих в каждой координатной четверти и не пересекающих оси координат. ...

Четверти на координатной плоскости - C++
Вводятся координаты точки на плоскости (X и Y, вещественные числа). Вывести номер координатной четверти, в которой расположена эта точка....

Определить номер координатной четверти. - C++
Даны координаты точки, не лежащей на координатных осях OX и OY. Определить номер координатной четверти, в которой находится данная точка.

В какой координатной четверти плоскости находится точка. - C++
1)определить в какой четверти координатной плоскости находится точка.

Проверить принадлежность точки второй координатной четверти - C++
Проверить истинность высказывания: &quot;Данные числа x, y являются координатами точки, лежащей во второй координатной четверти&quot;. ...

Определить лежат ли две точки в одной координатной четверти - C++
Даны координаты двух точек на плоскости, требуется определить, лежат ли они в одной координатной четверти или нет (все координаты отличны...

1
D_in_practice
331 / 331 / 159
Регистрация: 02.10.2014
Сообщений: 666
19.11.2014, 23:04 #2
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
Кроме утроения точек были еще ошибки? (передвинул оператор в строке 38)
C++
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
#include <iostream>
 
using namespace std;
 
int quarter(double x[], double y[]){
    
    if (x[0] * x[1] < 0 || x[0] * x[2] < 0 ||
         y[0] * y[1] < 0 || y[0] * y[2] < 0)
         return 0;
         
    if (x[0] < 0 || x[1] < 0 || x[2] < 0){
        if (y[0] < 0 || y[1] < 0 || y[2] < 0)
            return 3;
        else
            return 2;
    }else{
        if (y[0] < 0 || y[1] < 0 || y[2] < 0)
            return 4;
        else
            return 1;
    }
        
}
 
int main(){
   
   int n;
   cout << "n = ";cin >> n;
   
    int out[5] = {};
    for (int i = 1; i <= n; ++i){
        double x[3], y[3];
        for (int j = 1; j <= 3; ++j){
           cout << "x" << j << " = ";
           cin >> x[j - 1];
           cout << "y" << j << " = ";
           cin >> y[j - 1];           
       }
       ++out[quarter(x, y)];
   }
   
   for (int i = 1; i <= 4; ++i)
      cout << out[i] << ' ';
      cout << endl;
}
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
19.11.2014, 23:04
Привет! Вот еще темы с ответами:

Найти номер четверти координатной плоскости по заданным координатам - C++
Написать программу нахождения номера четверти N (арабскими цифрами) координатной плоскости, которой принадлежит заданная точка с...

Определить номер координатной четверти, в которой находится данная точка - C++
Даны координаты точки, не лежащей на координатных осях OX и OY. Определить номер координатной четверти, в которой находится данная ...

Найти площадь, лежащую в первой координатной четверти, прямоугольника, заданного вершинами. - C++
Заданы координаты вершин прямоугольника: (х1, у1), (х2, у2}), (х3, у3), (х4, у4). Найти площу частей прямоугольника, в первой координатной...

Написать выражение, соответствующее условию: точка не лежит в третьей четверти координатной плоскости - C++
Запишите выражение соответствующие следующему условию: точка не лежит в третьей четверти координатной плоскости.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru