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

Добавить в код любые пользовательские функции (лучше всего - функции ввода/вывода) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Найти наибольшее из 4 чисел http://www.cyberforum.ru/cpp-beginners/thread1621220.html
Всем добрый вечер! Помогайте)) Нужно найти все возможные варианты нахождения наибольшего числа из 4 чисел. То есть когда некоторые числа равны, или же даже наибольшие равны.Заранее спасибо!!
C++ Вычислить функции arcctgс заданной точностью с использованием разложения в ряд Помогите довести программу до рабочего состояния. Задание. Составить схему программы и программу на языке C++ с использованием оператора цикла с предусловием и оператора цикла с постусловием для вычисления функции arcctgс заданной точностью с использованием разложения в ряд: # include <iostream> # include <cmath> using namespace std; http://www.cyberforum.ru/cpp-beginners/thread1621196.html
C++ Быстрое преобразование Фурье
Реализовывал БПФ, но столкнулся с двумя проблемами. Вторая - в комментарии, а первая где-то в цикле (отметил), т.к. эмпирическим путём (комментирование) вроде как признал в нём проблему. Кто-нибудь может подсказать? Код вроде как простейший написан. #include <iostream> #include <cmath> #include <windows.h> using namespace std; #define pi 3.141592633589793
Доказать (перебор) что для любых величин А, В, С типа Boolean следующие пары логических выражений эквивалентны C++
Доказать (путем перебора возможных значений), что для любых величин А, В, С типа Boolean следующие пары логических выражений имеют одинаковые значения (эквивалентны): A AND (В OR С) и (A AND В) OR (A AND С)
C++ Ввести номер дня недели и вывести его название http://www.cyberforum.ru/cpp-beginners/thread1621178.html
Ввести номер дня недели. Вывести его название C++ VS p.s sps Добавлено через 1 час 38 минут разобрался)) #include <iostream> using namespace std; void main() { setlocale (LC_ALL, "Russian");
C++ Не работает сортировка в двумерном массиве Уже вторую неделю не могу заставить работать прогу на C++ Задание было: Упорядочить строки целочисленной прямоугольной матрицы по возрастанию количества одинаковых элементов в каждой строке. Найти номер первого из столбцов, не содержащих ни одного отрицательного элемента. Поиск первого столбца работает, повторения вроде бы находит и выводит, но сортировка просто не происходит. ... подробнее

Показать сообщение отдельно
olya7
477 / 294 / 91
Регистрация: 18.02.2013
Сообщений: 684
21.12.2015, 20:25
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
#include <cstdlib>
#include <clocale>
#include <ctime>
#include <cmath>
#include <math.h>
#include <streambuf>
#include <fstream>
#include <iostream>
 
using namespace std;
int point [30][2];
int okr [30][3];
const int nmax=30;
 
/* функция определяет пересекается прямая с окржуностью или нет */
bool Peres(double *a, double *b, double *c)
{
    double h; /*строим треугольник с концами в координатах прямой и вершиной в центре окружности. Ищем высоту от координаты окружности к прямой*/
    h = (abs((b[1]-a[1])*c[1] + (a[0]-b[0])*c[0] + (a[0]*b[1] - a[1]*b[0])))/(sqrt((b[1]-a[1])*(b[1]-a[1])+(a[0]-b[0])*(a[0]-b[0])));
    return (h<c[2]); // если высота меньше радиуса, пересекаются
}
 
void input(double **a,int n,int m)
{
    for(int i=0;i<n;i++)
        for(int j=0;j<m;j++)
            cin>>a[i][j];
 
}
 
int main() {
        setlocale(0, "rus");
int n,m,i,j,k,p,mx,imx,jmx;
    double  **a;
    double  **b;
 
 
    do {
        cout << "Количество точек до " << nmax << " n=";
        cin >> n;
    }while(n<2 || n>30);
 
    do {
        cout << "Количество окружностей до " << nmax << " m=";
        cin >> m;
    }while(m<1 || m>30);
a=new double*[n];
for (int i=0;i<n;i++)
    a[i]=new double[2];
b=new double*[n];
for (int i=0;i<n;i++)
    b[i]=new double[2];
        {
            int q;
            cout<<"Введите номер выбранного варианта\n1) ввод с консоли\n2) работа с файлом:\n";
 
cin>>q;
if(q == 1)
    {
   /* for(i=0; i<n; i++) {
 
    cin >> a[i][0];
    cout << "Y=";
    cin >> a[i][1];*/  cout << "Введите координаты точек\n";
    input(a,n,2);
     for(int i=0;i<n;i++){
        for(int j=0;j<m;j++)
            cout<<a[i][j]<<"\t";
            cout<<endl;}
 
    for(i=0; i<m; i++) {
        cout << "Введите координаты окружности("<<i+1<<"):\nX=";
    cin >> b[i][0];
    cout << "Y=";
    cin >> b[i][1];
    cout << "R=";
    cin >> b[i][2];
    }
}
else if(q == 2){
 
    ifstream ffin("point.txt");
 
if (!ffin)
    cout<<"ERROR: not file "<<endl;
    else
    {
for (i=0; i<n; i++){
ffin>>a[i][0]>>a[i][1];
cout<<" X=:"<<a[i][0]<<" Y=:"<<a[i][1]<<endl;
}
    }
    ifstream fin("okr.txt");
if (!fin)
    cout<<"ERROR: not file "<<endl;
    else
    {
        for (i=0; i<n; i++){
 
fin>>b[i][0]>>b[i][1]>>b[i][2];
cout<<" X=:"<<b[i][0]<<" Y=:"<<b[i][1]<<" R=:"<<b[i][2]<<endl;
}
    }
 }
else cout<<"Error"<<endl;
{
    system ("pause");
}
 
        }
    cout << "Координаты точек:\nX:";
    for(i=0;i<n;++i)
        cout << a[i][0] << " ";
    cout << "\nY:";
    for(i=0;i<n;++i)
        cout << a[i][1] << " ";
    cout << "\n\nПараметры окружностей:\nX:";
    for(i=0;i<m;++i)
        cout << b[i][0] << " ";
    cout << "\nY:";
    for(i=0;i<m;++i)
        cout << b[i][1] << " ";
    cout << "\nR:";
    for(i=0;i<m;++i)
        cout << b[i][2] << " ";
    cout << "\n\n";
    /* ищем прямую с максимальными пересечениями */
    mx=0;
    imx=0;
    jmx=0;
    for(i=0;i<n-1;++i)
        for(j=i+1;j<n;++j)
        {
            k=0;
            for(p=0;p<m;++p)
                if(Peres(a[i],a[j],b[p]))
                    k=k+1;
            if(k>mx)
            {
                mx=k;
                imx=i;
                jmx=j;
            }
        }
  if(mx==0)
        cout << "Нет пересекающихся прямых с окружностями\n";
    else
        cout << "Максимальное число пересечений прямой с окружностями="<< mx
            << "\nЭта прямая проходит через точки ("<<a[imx][0]<<';'<<a[imx][1]<<") и ("<<a[jmx][0]<<';'<<a[jmx][1]<<")\n";
    cout << "\n";
    delete []a;
    delete []b;
    //system("pause");
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru