Форум программистов, компьютерный форум, киберфорум
Наши страницы

fopen("input.txt","r") не работает - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Опишите сортировку элементов линейного массива http://www.cyberforum.ru/cpp-beginners/thread1044734.html
Помогите. Опишите сортировку элементов линейного массива. С помощью этой функции составьте программу, которая упорядочивает по убыванию элементы столбцов двухмерного массива. //использовать...
C++ алгорит для нахождения элеманта с заданным условие Добрый день. Дано задание: используя подходящий алгоритм, найти в контейнере элемент, удовлетворяющий заданному условию. Контейнер с собственным типом данным. У меня это имя и возраст. Помогите... http://www.cyberforum.ru/cpp-beginners/thread1044731.html
C++ Обработка массива
Помогите, пожалуйста, реализовать: данные считаны в формате firsTeam firstScore secondScore secondTeam input.txt 6 Manchester 1 2 Liverpool Manchester 2 2 Arsenal Manchester 1 1 Chelsea
Дана матрица целых чисел, из n строк и n столбцов (n < = 100).Определить является ли матрица нулевой (состоит из одних нулей) C++
#include <iostream.h> #include <iomanip.h> #include<conio.h> void main() { int mas; int N; int max_element; int count_max_element = 0;
C++ Наследование классов http://www.cyberforum.ru/cpp-beginners/thread1044721.html
Создать иерархию классов. Базовый класс - производный класс. Базовый класс: Поле данных - одномерный массив чисел целого типа (16 бит). Реализовать перегруженный метод : 1)без аргументов -...
C++ Оценка псевдослучайной последовательности Нужно сдать семестровую к пятнице, помогите если сможете (задание на картинке), если кому поможет вот мои наброски: #include <iostream> #include <cmath> using namespace std; const int n=150,... подробнее

Показать сообщение отдельно
SuperVarenik
0 / 0 / 0
Регистрация: 26.04.2013
Сообщений: 24

fopen("input.txt","r") не работает - C++

16.12.2013, 23:41. Просмотров 432. Ответов 0
Метки (Все метки)

Приветствую)
Ближе к делу. -> Есть код работы алгоритма получения начальных отрезков многопутевого слияния. Сам алгоритм не важен не вдавайтесь.
Дело в том, что входные данные должны находиться в файле, там у меня массив чисел. Так вот когда я применяю
FILE* stri;
stri=fopen("input.txt", "r"); вроде уже созданный файл должен открытатться для потока stri;


Проблема в том что в среде NetBeans все работает нормально и файл открывается, а вот после того как я делаю Собрать, т е получаю .exe файл программы. То когда я создаю рядом с .exe шником в одной папке input.txt то он его не открывает и программа дальше зависает так как работает не правильно. То что проблема в открывании файла проверяю через if(stri==NULL) выдает истину! Вот КОД:
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
#define UZEL struct otrezok
#include <algorithm>
#include<iostream>
#include<stdio.h>
#include <limits>
using namespace std;
 
UZEL
{
    char RECORD;
    int KEY; 
    UZEL* LOSER;
    int RN;
    UZEL*PE;
    UZEL*PI;
};
 
int main()
{
    int N;
    cout<<"Vvedite kolichestvo kluchei : ";
    cin>>N;
    cout<<endl;
        int P;
        cout<<"Vvedite P : ";
    cin>>P;
    cout<<endl;
        
    UZEL *X=new UZEL[P-1];
        FILE* stri;
        [C]stri=fopen("input.txt","r");
           if (stri==NULL) 
        {
            cout<<"Error opening file"<<endl;
            system("pause");
            return 0;
        }[/C]
        FILE* stro;
        stro=fopen("output.txt","w");
        int tmp=1;
        int RMAX;
        int RC;
        int RQ;
        int LASTKEY;
        UZEL* Q;
        UZEL* J;
        UZEL* T;
    while(tmp)
    {
        switch(tmp)
        {
        case 1:
                    RMAX=0;
                    RC=0;
                    LASTKEY=numeric_limits<int>::max( );
                    Q=&X[0];
                    RQ=0;
                    for(int j=0;j<P;j++)
                    {
                        J=&X[j];
                        J->LOSER=J;
                        J->RN=0;
                        J->PE=&X[(P+j)/2];
                        J->PI=&X[j/2];
                    }
                    
        case 2:
                    if(RQ==RC)
                    {
                        tmp=3;
                        break;
                    }
                    else
                    {
                       RQ=RC+1;
                       if(RQ>RMAX)
                       {
                         tmp=0;
                         break;
                       }
                       else
                       {
                        RC=RQ;
                       }
                       fprintf(stro,"\n Otrezok %d: ",RQ);  
                    }
                    
        case 3:
                    if(RQ!=0)
                    {
                        fprintf(stro,"%d ",Q->KEY);
                        LASTKEY=Q->KEY;
                    }
                    
        case 4:
                    if(feof(stri))
                    {
                        RQ=RMAX+1;
                        tmp=5;
                        break;
                    }
                    else
                    {
                        fscanf(stri,"%d",&Q->KEY);
                        if((Q->KEY)<LASTKEY)
                         {
                             RQ=RQ+1; 
                         }
                    
                        if(RQ>RMAX)
                         {
                             RMAX=RQ;
                         }
                    }
                    
        case 5:
                    T=Q->PE;
                    
        case 6:
                    if(((T->RN)<RQ)||((T->RN==RQ)&&(((T->LOSER)->KEY)<(Q->KEY))))
                    {
                        swap(T->LOSER,Q);
                        swap(T->RN,RQ);
                    }
                    
        case 7:
                    if(T==&X[1])
                    {
                        tmp=2;
                        break;
                    }
                    else
                    {
                        T=T->PI;
                        tmp=6;
                        break;
                    }
                    
        }
    }
        fclose(stro);
        fclose(stri);
        delete[] X;
    system("pause");
        return 0;
}
Вот .exe + библиотеки мало ли у кого не запуститься и там еще 2 файла input тот самый и output внутри уже забитые примеры:
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru