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

Исправить программу, чтоб считывала текст из файла Input.txt и выводит в файл Output.txt - C++

Восстановить пароль Регистрация
 
tvboy
0 / 0 / 0
Регистрация: 24.01.2013
Сообщений: 99
07.02.2013, 08:39     Исправить программу, чтоб считывала текст из файла Input.txt и выводит в файл Output.txt #1
Даны координаты центра и радиус R окружности, координаты точки. Найти точки пересечения касательных с окружностью

input.txt 1 1 1 2 2 output.txt 2 1.00 2.00 2.00 1.00

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>
#include <cmath>
 
using std::cout; using std::cin; using std::endl; 
 
double distance(const double x1, const double y1, const double x2, const double y2) {
    return sqrt(pow((x1 - x2), 2) + pow((y1 - y2), 2));
}
 
void findPointsOfContact(const double& xc, const double& yc, const double& R, const double& xn, const double& yn,
    double& xa, double& ya, double& xb, double& yb, const double& l) 
{
    double e = xc - xn; double c = yc - yn;
    double q = (l*l - R*R + yc*yc - yn*yn + xc*xc - xn*xn)/2;
    double A = c*c + e*e; 
    double B = (xc*e*c - c*q - yc*e*e)*2;
    double C = xc*xc*e*e - 2*xc*e*q + q*q + yc*yc*e*e - R*R*e*e;
    ya = (sqrt(B*B - 4*A*C) - B) / (2*A);
    yb = (- sqrt(B*B - 4*A*C) - B) / (2*A);
    xa = (q - ya*c)/e;
    xb = (q - yb*c)/e;
}
 
int main()
{
    double xc, yc, R, xn, yn;
    double xa, ya, xb, yb;
    xa = ya = xb = yb = 0;
    cout << "Enter coordinates" << endl;
    cin >> xc >> yc >> R >> xn >> yn;
    double CN = distance (xc, yc, xn, yn);
    double l = sqrt(CN*CN - R*R);
    if (CN > R) {
        findPointsOfContact (xc, yc, R, xn, yn, xa, ya, xb, yb, l);
        cout << "2 " << xa << " " << ya << " " << xb << " " << yb << endl;
    }
    else if (CN = R) {
        cout << "1 " << xn << " " << yn << endl;
    }
    else if (CN < R) {
        cout << "There are no contact points" << endl;
    }
    system("pause");
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.02.2013, 08:39     Исправить программу, чтоб считывала текст из файла Input.txt и выводит в файл Output.txt
Посмотрите здесь:

C++ В файле input.txt содержатся сведения о группе студентов. переписать данные файла в файл output.txt, отсортировав их по возрастанию
Посчитать сколько в файле input.txt символов и записать их кол-во в output.txt C++
C++ Переписать данные файла input.txt в output.txt, отсортировав их
C++ Переписать данные файла input.txt в output.txt, отсортировав их
C++ Дан одномерный массив из n (n≤104) элементов, осортировать его по возрастанию методом выбора через input.txt, output.txt
C++ Переписать данные файла input.txt в файл output.txt, отсортировать их в алфавитном порядке по фамилии
C++ Найти минимальное и максимальное числа из input.txt и записать его в файл output.txt
Переписать данные файла input.txt в файл output, отсортировав их по возрастанию средней оценки методом выбора C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
SummerRain
 Аватар для SummerRain
325 / 324 / 17
Регистрация: 16.12.2012
Сообщений: 544
07.02.2013, 12:14     Исправить программу, чтоб считывала текст из файла Input.txt и выводит в файл Output.txt #2
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
#include <iostream>
#include <fstream>
#include <cmath>
#include <sstream>
 
using std::cout; using std::cin; using std::endl; 
 
// расстояние между точками
double distance(const double x1, const double y1, const double x2, const double y2) {
    return sqrt(pow((x1 - x2), 2) + pow((y1 - y2), 2));
}
 
// функция находит координаты пересечения точек касательных к окружности 
void findPointsOfContact(const double& xc, const double& yc, const double& R, const double& xn, const double& yn,
    double& xa, double& ya, double& xb, double& yb, const double& l) 
{
    double e = xc - xn; double c = yc - yn;
    double q = (l*l - R*R + yc*yc - yn*yn + xc*xc - xn*xn)/2;
    double A = c*c + e*e; 
    double B = (xc*e*c - c*q - yc*e*e)*2;
    double C = xc*xc*e*e - 2*xc*e*q + q*q + yc*yc*e*e - R*R*e*e;
    ya = (sqrt(B*B - 4*A*C) - B) / (2*A);
    yb = (- sqrt(B*B - 4*A*C) - B) / (2*A);
    xa = (q - ya*c)/e;
    xb = (q - yb*c)/e;
}
 
int main()
{
    double xc, yc, R, xn, yn; // координаты C - центра окружности, и N - точки, из которой проводятся касательные, R - длина радиуса
    double xa, ya, xb, yb;  // координаты точек пересечения касательных к окружности
    xa = ya = xb = yb = 0;
 
    std::ifstream fi("input.txt");
    std::string str;
    std::getline(fi, str);
    std::istringstream ss(str);
    ss >> xc >> yc >> R >> xn >> yn; // считываем из файла
 
    std::ofstream fo("output.txt");
 
    double CN = distance (xc, yc, xn, yn);  // расстояние от центра окружности до точки N
    double l = sqrt(CN*CN - R*R);  // расстояние от точки N до точки пересечения касательной с окружностью
    if (CN > R) {                  // если расстояние между точкой и центром окружности больше, чем радиус, то точек касания 2
        findPointsOfContact (xc, yc, R, xn, yn, xa, ya, xb, yb, l);
        fo << "2 " << xa << " " << ya << " " << xb << " " << yb << endl;  // выводим результат в файл
    }
    else if (CN = R) {             // если расстояние между точкой и центром окружности равно радиусу, то точек касания 1
        fo << "1 " << xn << " " << yn << endl;
    }
    else if (CN < R) {             // если расстояние между точкой и центром окружности меньше, чем радиус, то точек касания 0
        fo << 0 << endl;
    }
    //system("pause");
    return 0;
}
Yandex
Объявления
07.02.2013, 12:14     Исправить программу, чтоб считывала текст из файла Input.txt и выводит в файл Output.txt
Ответ Создать тему
Опции темы

Текущее время: 23:47. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru