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

минимальное подмножество отрезков - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ CLR http://www.cyberforum.ru/cpp-beginners/thread56956.html
Подскажите где можно почитать про написание CLR проектов. Желательно как можно подробнее. До этого имел дело только с консольными приложениями. CLR->Win32 Application почемуто единственный вид проектов, которые в моей VS++ Express Edition 2008 запускаются с редактором форм.
C++ Диапазон Просуммировать числа указанного диапазона. Начальное и конечное значение диапазона вводятся с клавиатуры. Программу написать с использованием функций. Кто может, напишите код программы! http://www.cyberforum.ru/cpp-beginners/thread56950.html
Каталог шаблонов C++
Может кто подскажет ? Как-то раз попадалась на глаза программа, которая позволяла вести древовидный каталог заметок, кусков кода. Можно было легко создавать новые разделы и потом легко переносился кусок сохраненного кода в текущий редактор. Поддерживалась подсветка синтаксиса для разных языков. Т.е. можно создавать свою библиотеку заготовок, подсказок,заметок. Может кто знает такой продукт или...
посчитать тангенс C++
Здравствуйте. Нужно посчитать тангенс от 0 до бесконечности. Я что-то не очень понимаю как этот цикл должен выглядеть.. что нибудь вроде этого? for (double i=0;;i+=1) Заранее спасибо.
C++ Выдает ошибки. http://www.cyberforum.ru/cpp-beginners/thread56895.html
Помогите разобраться, пишу программы в универе, запускаю и все работает, прихожу домой запускаю эту же программу, а С++ выдает мне сообщения об ошибки. Например вот код программы сортировки одномерного массива пузырьком: #include <iostream.h> #include <conio.h> int main() { int mas; int n, i, j, prom; cout << "\nVvedite n"; cin >> n; cout <<"\nVvedit masyv z "<< n <<"...
C++ С++ - указатель на функцию. Вот такой вот кодик: int main() { int *x = (int*) printf("%s","fuck!!!"); cout << *x; getch(); подробнее

Показать сообщение отдельно
TanT
эволюционирую потихоньку
465 / 463 / 43
Регистрация: 30.06.2009
Сообщений: 1,399
17.10.2009, 16:12     минимальное подмножество отрезков
пробуем, тестим.
ввод через фаил (в файле только пары (начало и конец) отрезков)
ввод организовал как мне удобно, а не по условию
на вывод отладки можно не заморачиваться, главное это результат
а промежуточный вывод для удобства

const int begDiapason = 0;
const int endDiapason = 100; - границы диапазона

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
#include <iostream>
#include <fstream>
#include <vector>
#include <algorithm>
 
using namespace std;
 
#define sizeVec(c) int((c).size())
#define all(c) (c).begin(),(c).end()
 
#define LENGTH(a)  ((*a).first) 
#define BEG(a)  ((*a).second.first) 
#define END(a)  ((*a).second.second)        
 
const int begDiapason = 0;
const int endDiapason = 100;
 
typedef  vector<pair< int, pair<int, int> > > SEGMENT;
int main()
{
    char *file="data.txt";
    int beg, end, counter=0;
    bool flag;
    SEGMENT arrSeg;
    SEGMENT::iterator itt;
 
    ifstream f(file);
    if (!(f.is_open()))  // проверка наличия первого файла с текстом
        cout<<"ERROR: not file "<<file;
    else
        while(!f.eof()) // чтении из файла
        {   
            f>>beg; f>>end;
            arrSeg.push_back(make_pair(end-beg, make_pair(beg, end)));
        }
 
 
    // вывод для отладки
    for (SEGMENT::iterator it=arrSeg.begin(); it<arrSeg.end(); it++)
        cout<<"length:"<<LENGTH(it)<<" beg:"<<BEG(it)<<" end:"<<END(it)<<endl;
    cout<<endl;
 
//  sort(all(arrSeg));  reverse(all(arrSeg));  // можно иначе
 
    beg=begDiapason; 
//  for (itt=arrSeg.begin(); itt<arrSeg.end(); itt++)
//     if (beg>=BEG(itt)) 
//      { beg=END(itt); break; }
// 
//  if(beg!=begDiapason) // если после первого поиска не обнаружен отрезок с begDiapason..Х
//  {
//      cout<<++counter<<". length:"<<LENGTH(itt)<<" beg:"<<BEG(itt)<<" end:"<<END(itt)<<endl;
//      arrSeg.erase(itt);
        
        while (!(arrSeg.empty()))
        {
            // достигли конца диапазона
            if (beg>=endDiapason) break;
            // подравниваем все отрезки под текущую позицию бегунка
            for (SEGMENT::iterator it=arrSeg.begin(); it<arrSeg.end(); it++)
                if (beg>BEG(it))    
                    { BEG(it)=beg; LENGTH(it)=END(it)-BEG(it); }
      // сортируем по убыванию (полезные длины отрезков поменялись)
            sort(all(arrSeg));  reverse(all(arrSeg)); 
 
            // ищем максимальный отрезок начинающийся с позиции бегунка
            flag=false;
            for (itt=arrSeg.begin(); itt<arrSeg.end(); itt++)
                if (beg>=BEG(itt)) 
                { flag=true; break; }
 
            if (flag==false) break;
            // если бегунок на отрезке длиной больше нуля
            // инкрементируем счётчик отрезков и по новой
            if (LENGTH(itt)>0)
            {
                cout<<++counter
                    <<". length:"<<LENGTH(itt)
                    <<" beg:"<<BEG(itt)
                    <<" end:"<<END(itt)<<endl;
                beg=END(itt);
                arrSeg.erase(itt);
            }
            else
                break;
        }
        
        if(beg>=endDiapason)
            cout<<"\nmin number segments: "<<counter;
        else
            cout<<"\nit cannot be done: ";
 
    f.close();  cout << endl;   system("PAUSE");
    return 0;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru