Форум программистов, компьютерный форум CyberForum.ru

Найти сумму площадей всех треугольников отдельно - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Удалить элементы списка, что принадлежат промежутку http://www.cyberforum.ru/cpp-beginners/thread1016900.html
помогите решить задачу: Дано целочисленный список F = <1,8,9,0,1,3,2,4,1,12,23,1,23,2,19,1>. Удалить элементы принадлежат промежутку (a; b), если задаются с клавиатуры.
C++ Не могу сделать лабу Помогите решить задание Описати функцію, що здійснює циклічний зсув на n позицій праворуч елементів цілочисельного масиву, що містить m елементів (n<m). http://www.cyberforum.ru/cpp-beginners/thread1016894.html
Подобие MessageBox выводящего INT и LPCSTR . Не тупо ли ? C++
Привыкшему к удобствам PHP с++ нубу захотелось сделать такое вот извращение.. Функция выводит текст как INT типа так и строкового типа... template< typename mytype > void pre(mytype var) { LPCSTR str; const char * type = typeid(var).name(); if (!strcmp("int", type)) { char buffer;
C++ Ввод строк на с++
Есть задание. Вводить с клавиатуры строки, пока не будет введено 5 строк, заканчивающихся любыми шестнадцатеричных цифр. Вывести все введенные строки и строки, соответствующие требованиям задания. Отсортировать строки. Вывести длинный строку (строки, если их несколько). Есть код. #include <iostream.h> #include <conio.h> #include <ctype.h> //обработка символов #include <string.h>...
C++ Работа со списками http://www.cyberforum.ru/cpp-beginners/thread1016885.html
Помогите решить задание. Описати функцію, яка друкує у зворотному порядку значення елементів списку. Тип даних - double
C++ Двухмерный массив, среднее значение столбцов, сортировка по возрастанию этих значений Дано матрицу i = 6 j = 6. Найти среднее значение элементов столбцов (Ei / ni) и переставить эти значения столбцов по возрастанию определителей. Есть код начала, но я незнаю как переставить эти средние значения столбцов по возрастанию определителей. #include <iostream.h> #include <math.h> #include <conio.h> void main() { clrscr(); int a; int i,j,sum; подробнее

Показать сообщение отдельно
katsidelin
 Аватар для katsidelin
60 / 21 / 2
Регистрация: 15.11.2013
Сообщений: 112
Записей в блоге: 3
24.11.2013, 20:04     Найти сумму площадей всех треугольников отдельно
Мне некогда с Вами спорить.

Добавлено через 3 минуты
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
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
 #include <cmath> // У меня gcc 4.8.2 Linux. У Вас может быть другая библиотека.
 #include <fstream>
 #include <iostream>
 
using namespace std;
 
int main(int argc, char* argv[])
{
    // Пусть имеется в каталоге (папке) с программой текстовый файл с указанными Вами данными.
    // Например, source.cfg
    const char szSourceFile[11] = "source.cfg"; // Переменная с именем файла.
 
    // Внутри файла есть как текстовые (тип char), так и целочисленные (тип int, но я использую float - с плавающей точкой) значения.
    // Из названия Вашей темы следует, что нужно использовать структуру.
    struct aTreug
    {
        char t; // Текстовая составляющая.
        float f[3];    // Числовая составляющая, состоящая либо из трёх цифер, либо из одной. Как в последнем случае.
    };
    // Открываем входящий файловый поток.
    ifstream vvod;
    vvod.open(szSourceFile, ios_base::in);
    // Заполняем поля структуру.
    aTreug Base[4]; // Переменная с типом данных - структура (в стеке).
    int i=0;    // Переменная счётчик.
    while ( !vvod.eof() )
    {
        vvod >> Base[i].t;
        if (Base[i].t == 'T')   // Я заменил букву на латинскую, чтобы не было проблем с юникодом. В виндовсе поменяйте надаз на русскую.
        {
            vvod >> Base[i].f[0];
            vvod >> Base[i].f[1];
            vvod >> Base[i].f[2];
        }
        else if (Base[i].t == 'K')   // Я заменил букву на латинскую, чтобы не было проблем с юникодом. В виндовсе поменяйте надаз на русскую.
        {
            vvod >> Base[i].f[0];
        }
        else
        {
            // Не делаем ничего.
        };
 
        i++;
    };
    // Закрываем файловый поток.
    vvod.close();
 
    // Коэффициент подобия показывает во сколько раз соотносятся соответсвующие стороны треугольника.
    // Если при делении сторон двух треугольников везде будет число К, то треугольники подобны.
    // Тогда можно будет искать их площади по формуле Герона.
    // [url]http://ru.wikipedia.org/wiki/%D4%EE%F0%EC%F3%EB%E0_%C3%E5%F0%EE%ED%E0[/url]
 
    int n=0; // Счётчик для нового цикла.
    float S[i]; // Массив площадей для подобных треугольников.
    while ( Base[n].t == 'T' && Base[n+1].t == 'T' )
    {
        if (
                (Base[n].f[0]/Base[n+1].f[0] == Base[i].f[0] || Base[n].f[0]/Base[n+1].f[0] == 1 /(Base[i].f[0]))
                    &&
                (Base[n].f[1]/Base[n+1].f[1] == Base[i].f[0] || Base[n].f[1]/Base[n+1].f[1] == 1 /(Base[i].f[0]))
                    &&
                (Base[n].f[2]/Base[n+1].f[2] == Base[i].f[0] || Base[n].f[2]/Base[n+1].f[2] == 1 /(Base[i].f[0]))
            )
        {
            S[n] = sqrt( ((Base[n].f[0] + Base[n].f[1] + Base[n].f[2])/2 ) * ((Base[n].f[1] + Base[n].f[0]))* ((Base[n].f[0] + Base[n].f[2]))* ((Base[n].f[1] + Base[n].f[2])) );
            S[n+1] = sqrt( ((Base[n+1].f[0] + Base[n+1].f[1] + Base[n+1].f[2])/2 ) * ((Base[n+1].f[1] + Base[n+1].f[0]))* ((Base[n+1].f[0] + Base[n+1].f[2]))* ((Base[n+1].f[1] + Base[n+1].f[2])) );
 
            cout << S[n] << '\t' << S[n+1] << endl;
        }; // Я немного преобразовал формулу. Проверьте, я не очень великий математик.
 
        cout << n << endl;
 
        n++;
    };
 
 
    return 0;
};
Предлагаю лучше гению Си объяснить, что я делаю не так?
Последний кусок кода не работает, так как я ожидал.
 
Текущее время: 17:42. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru