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

Метод сортировки в файле - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Поменять местами элементы http://www.cyberforum.ru/cpp-beginners/thread55973.html
// Lab5. Задача 1.cpp : Defines the entry point for the console application. // Задан двумерный массив float a. Поменять местами max среди отрицательных элементов и min среди положительных #include "stdafx.h" #include "conio.h" int _tmain(int argc, _TCHAR* argv) { float a,MaxOtr,MinPol; int r,c,k1,k2,l1,l2;
C++ в чем ошибка ?(( Программа для возведеня в степень число, я не понимаю в чём проблема #include <iostream> using namespace std; int main(); int j=1; i , N, w; cout << "vvedite 4islo" << endl; cin >> i << endl; w=i; cout << "vvedite stepen'" << endl; http://www.cyberforum.ru/cpp-beginners/thread55969.html
Массивы C++
Помогите пожалуйста со следующими заданиями: 1. Даны числа n и m (вводятся с клавиатуры). Создайте массив int A и заполните его следующим образом (ниже приведен пример для n=4 и m=6): 0 1 3 6 10 14 2 4 7 11 15 18 5 8 12 16 19 21 9 13 17 20 22 23 Выведите массив на экран, отводя на вывод каждого числа ровно 3 символа....
Сумма элементов трехмерного массива C++
Имеется трехмерный массив из 3-ех слоев по 3Х3 элемента в каждом слое, в первом слое все элементы единицы, во втором слое - двойки, в третьем слое - тройки. Имеется цикл, заполняющий массив этими элементами. Что нужно добавить, чтобы найти сумму всех элементов массива? int** mass=new int*; for(int i=0;i<3;i++) mass=new int; for(int i=0;i<3;i++){ for(int j=0;j<3;j++) { ...
C++ Сортування вибором http://www.cyberforum.ru/cpp-beginners/thread55943.html
Написати програму алгоритмічною мовою С++ згідно з завданням, отриманим від викладача за табл. 1: задану прямокутну матрицю A={aij} відсортувати за вказаним алгоритмом; для відсортованої матриці знайти значення функції F(fi(aij)); алгоритм сортування оформити у вигляді процедури; обчислення fi(aij) оформити у вигляді функції; елементи матриці вводити з клавіатури; програма повинна вивести на...
C++ Как преобразовать длинное имя в короткое Добрый день! Помогите, пожалуйста, разобраться с функцией: DWORD GetShortPathName(LPCTSTR lpszLongPath, LPTSTR lpszShortPath, DWORD cchBuffer); получаю длинный путь, используя LongName = OpenDialog1->FileName; а в результате надо получить переменную ShortName = имя файла (например ShortName ="zu.txt") Или подскажите, как иначе можно решить задачу: есть текстовые файлы с данными,... подробнее

Показать сообщение отдельно
KillKenny
Сообщений: n/a
17.10.2009, 17:47     Метод сортировки в файле
почему не работает следующая функция?

после close() open() почему-то указатель остается в конце файла. помогите пожалуйста...


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
void Farm::sortFile(char* ch1, char* ch2)
    {   
        ifstream f;
        f.open(ch1);
        int fcount;
        f>>fcount;
        if (!ch2)
        {
            ch2="files/temp.txt"; //??
        }
        ofstream fo;
        fo.open(ch2);
        fo<<fcount<<"\n";
        int scount=0;
        Plant* P1=new Plant;
        Plant* P2=new Plant;    
        Plant* P3=new Plant;    
        P1->scan_f(f);
        while(!f.eof())
        {
            P2->scan_f(f);
            if ((*P1)>(*P2))
            {
                (*P1)=(*P2);
            }
        }
//      f.seekg(0,ios::beg);
        f.close();
        f.open(ch1);
//      ifstream f(ch1);
        int test;
        f>>test;
        while(!f.eof())
        {
            P2->scan_f(f);
            if (*P2 == *P1)
            {
                scount++;           
                P1->print_f(fo);
            }
        }
        while (scount<fcount)
        {
            f.close();
            f.open(ch1);
            f>>fcount;
            P2->scan_f(f);
            while(!((*P2)>(*P1)))
            {
                P2->scan_f(f);
            }
            while(!f.eof())
            {
                P3->scan_f(f);
                if (((*P2)>(*P3)) && ((*P3)>(*P1)))
                {
                    *P2=*P3;
                }
            }
            f.close();
            f.open(ch1);
            f>>fcount;
            while(!f.eof())
            {
                P3->scan_f(f);
                if (*P3 == *P2)
                {
                    scount++;           
                    P1->print_f(fo);
                }
            }
            *P1=*P2;
        }
        delete P1;
        delete P2;
        delete P3;
        f.close();
        fo.close(); 
    }
 
Текущее время: 15:06. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru