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

Найти даты "С или С++" - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ выдача списков по данным http://www.cyberforum.ru/cpp-beginners/thread323838.html
Сведения об учинике состоят из его имени и фамилии и названия класса (года обучения и буквы). 1.Выдать список однофамильцев во всей школе. 2.Выдать список однофамильцев в каких либо параллельных классах. 3.Выдать список однофамильцев в указаном пользователем классе. 4.Выдать список классов, в которых насчитывается более n учащихся.
C++ Извиняюсь за неудобства Решение не нужно только подсказать где можно найти и научиться решение подобных задач. Большое спасибо за то что научили пользоваться сайтом. Написать программу для вычисления и вывода на экран значений x и y. xi = 1,2,3,4.2,5 http://www.cyberforum.ru/cpp-beginners/thread323828.html
Глюк при заполнении массива C++
Заполняю массив float row float j=0; for (int i=0;i<501;i++) { row=j; cout<<j<<endl; j += 0.02; }
Упражнение из учебника С. Липпмана C++
1. Напишите программу, которая запрашивает у пользователя два числа и выводит на стандартное устройство вывода все числа, которые находятся между ними. #include "stdafx.h" #include <iostream> #include <windows.h> int main(){ using namespace std; setlocale( LC_ALL,"Russian" ); char res; int v1, v2, upper, lower;
C++ Начертите блок схему! http://www.cyberforum.ru/cpp-beginners/thread323802.html
Удалить из s1, ... , sn все слова с нечетными порядковыми номерами и перевернуть все слова с четными номерами. Например, если n=21 и данная последовательность символов представляет собой последовательность во_что_бы_то_ни_стало, то должна получиться последовательность отч_от_олатс. #include <stdio.h> #include <string.h> #include <conio.h> int main ( ) { int i=0; //объявление...
C++ предмет системное ПО нужно изучить эти направления. Списка литературы нет. 1. Многопоточное программирование (основные принципы создания многопоточных приложений, создание/удаление потоков, способы синхронизации потоков). 2. Работа с графикой (получение контекста устройства, основные графические объекты и их параметры, векторная и растровая графика). 3. Динамически подключаемые библиотеки (создание DLL,... подробнее

Показать сообщение отдельно
xAtom
 Аватар для xAtom
910 / 735 / 60
Регистрация: 09.12.2010
Сообщений: 1,346
Записей в блоге: 1
22.06.2011, 02:29     Найти даты "С или С++"
MaRsHaL!, вот попробуй как вариант.

Формат файла с датами такой:
2010-09-03 1991-01-01 1998-11-23 1990-03-23 1999-04-15 2002-05-01 2007-04-25
1999-04-09 2003-10-20 2002-08-02 2000-07-07 2001-09-11 2010-08-30
2010-09-02


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
#include <vector>
#include <fstream>
#include <iostream>
#include <conio.h>
using namespace std;
 
 
 
struct  sdate {
    long year, month, day;
    sdate(void) {}
    sdate(const char* _date) {
        year = month = day = 0;
        sscanf(_date, "%d-%d-%d", &year, &month, &day); 
    }
    long  stamp(void) {
         return year * 12 * 30 + month * 30 + day;
    }
};
 
 
 
 
 void  main(void){
 
    vector<sdate>  vdate;
    int  i = 0;
 
    fstream file;
    file.open("X:\\date.txt", ios_base::in); 
 
    while(!  file.eof() ) {
 
        char buf[1024];
        file.getline(buf, sizeof(buf), '\n');
        char*  tok = strtok(buf, " \t");
 
        while( tok ) {
            vdate.push_back( sdate(tok) );
            tok = strtok(NULL, " \t");
        }
 
    }
    file.close();
    file.clear();
 
 
           // ищем минимальную дату
    long  year_m = (vdate.size()) ? vdate[0].stamp() :  9999;
    int  index      = -1;
    for(i = 0; i < vdate.size(); i++) {
        if( vdate[i].stamp() <= year_m ) {
            year_m = vdate[i].stamp();
            index = i;
        }
    }
    if(index != -1) {
        cout << "min date: " << vdate[index].year << '-' 
                             << vdate[index].month << '-' << vdate[index].day << endl;
            }
 
           // ищем только весенние даты
    for(i = 0; i < vdate.size(); i++) {
        if(vdate[i].month >= 3 && vdate[i].month <= 5) {
            cout << "Vesna date: " << vdate[i].year << '-' 
                                        << vdate[i].month << '-' << vdate[i].day << endl;
                       }
    }
 
 
           // ищем самую позднию дату
    year_m = 0;
    index    = -1;
    for(i = 0; i < vdate.size(); i++) {
        if( vdate[i].stamp() > year_m ) {
            year_m = vdate[i].stamp();
            index = i;
        }
    }
    if(index != -1) {
          cout << "max date: " << vdate[index].year << '-' 
                        << vdate[index].month << '-' << vdate[index].day << endl;
    }
 
    vdate.clear();
 
    cin.get();
}
 
Текущее время: 18:24. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru