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

Компилятор ругается на fopen - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Как реализовать поиск значения,которое находится в стеке? http://www.cyberforum.ru/cpp-beginners/thread1626980.html
нужно найти значение.Значение находится в стеке.Как реализовать поиск? Пробовал через массив сделать что-то не получается вот код #include "stdafx.h" #include <stdlib.h> #include <string.h> #include <conio.h> #include <stdio.h> #include <iostream> #define ERROR_OPEN_FILE -3
C++ Ошибка "Expression expected" #pragma hdrstop #pragma argsused #ifdef _WIN32 #include <tchar.h> #else typedef char _TCHAR; #define _tmain main #endif #include <iostream> http://www.cyberforum.ru/cpp-beginners/thread1626963.html
Конвертировать двухбайтовую строку в однобайтовую C++
Как перевести без потери данных? Из wchar_t wPass В byte bPass Подсказали так: std::copy(wPass, 256, reinterpret_cast<WCHAR *>(bPass)); Не работает...
Написать программу решения простейшего дифференциального уравнения с запаздывающим аргументом C++
Нужно запрограммировать решение простейшего дифференциального уравнения с запаздывающим аргументом: Кто нибудь может кинуть пример подобной программы, подсказать библиотеку для интегрирования или как вообще это кодируют, хоть что-нибудь ?
C++ Функция вычисляющая стоимость товара с налогом http://www.cyberforum.ru/cpp-beginners/thread1626883.html
напишите функцию add_tax типа void.у неё два формальных параметра :taxRate,значение которого представляет налог с продажи в процентах ,и cost,значение которого представляет стоимость товара без налога.Функция изменяет значение параметра cost ,что бы оно включало налог с продажи.
C++ Определить периметр треугольника, заданного координатами вершин Определить периметр треугольника, заданного координатами вершин. Длину стороны треугольника вычислять в функции. Посчитать среднее арифметическое периметров трех треугольников, координаты которых ввести с клавиатуры. #include <iostream.h> #include <math.h> float dl(int, int, int, int); float s(float, float, float); int main (){ int x, y; float max=0; int i; float a, b, c; подробнее

Показать сообщение отдельно
Xerasima
0 / 0 / 0
Регистрация: 23.10.2015
Сообщений: 30
27.12.2015, 18:34     Компилятор ругается на fopen
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
#include<iostream>
#include<stdio.h>
#include <string.h>
#define MAX 50
using namespace std;
 
 
// Приоритет операций
int prioritet(char var)
{
    switch (var)
    {
    case '^':                        return 6;
    case '*': case '/':              return 4;
    case '+': case '-':              return 2;
    case '(': case ')': case '#':    return 1;
    }
}
int operand(char var) //Проверка операндов
{
    if (var >= '0' && var <= '9')
        return 1;
}
int operation(char var) //Проверка операции
{
    if (var == '(' || var == ')' || var == '+' || var == '-' || var == '*' || var == '/')
        return 1;
}
 
class stack
{
    int tos = 0;
    char a[100];
public: // доступны в любом месте программы
    void push(char i, int max) //Затолкать элемент в стек.
    {
        if (tos>max)
        {
            printf("Stack polon \n");
            return;
        }
        a[tos] = i;
        tos++;
    }
    int pop(void) //Получить верхний элемент стека.
    {
 
        if (tos<0)
        {
            printf("Stack pust\n");
            return 0;
        }
        tos--;
        return a[tos];
    }
    int hi_stack()//Приоритет вершины стека
    {
        return prioritet(a[tos - 1]);
    }
    int isempty() //Пуст ли стек
    {
        return tos == 0;
    }
};
 
int main()
{
    int len = 0, j = 0, p = 0, i;
    char in[MAX], out[MAX];//Входная и выходная строки
    stack s;
    FILE *in1, *out1;
    in1 = fopen("in.txt", "r");
    out1 = fopen("out.txt", "w");
    while (!feof(in1))//Считываем входную строку из файла и ищем длину строки
    {
        fscanf(in1, "%c", &in[j]);
        j++;
        len++;
    }
    j = 0;
    while (j<len)//Перевод в ОПЗ
    {
        if (operand(in[j]) == 1)//Операнд перемещается в выходную строку
        {
            out[p] = in[j];
            p++;
        }
        else if (operation(in[j]) == 1 && (s.isempty() || prioritet(in[j]) == s.hi_stack()))//Операция проталкивается в стек, если он пуст
        {                                                                       //или приоритеты равны
            s.push(in[j], len);
        }
        else if (operation(in[j]) == 1 && !s.isempty() && prioritet(in[j])>s.hi_stack())//Операция проталкивается в стек,
        {                                                                       //если приоритет символа вершины стека больше
            s.push(in[j], len);
        }
        else if (operation(in[j]) == 1 && !s.isempty() && prioritet(in[j])<s.hi_stack() && prioritet(in[j])>1)//Операция проталкивается в стек, предварительно
        {                                                                       //вытолкнув в выходную строку все символы операций
            while (s.hi_stack() >= prioritet(in[j]) && !s.isempty())                //с меньшим или равным приоритетом
            {
                out[p] = s.pop();
                p++;
            }
            s.push(in[j], len);
        }
        else if (in[j] == '(')          //Левая открывающая скобка проталкивается в стек
        {
            s.push(in[j], len);
        }
        else if (in[j] == ')')//Правая закрывающая скобка выталкивает в выходную строку все символы до левой открывающей скобки,
        {             //сами скобки уничтожаются, не попадая в выходную строку
            while (!s.isempty())
            {
                if (s.hi_stack()>1)
                {
                    out[p] = s.pop();
                    p++;
                }
                else
                {
                    s.pop();
                    break;
                }
            }
        }
        else if (j == len - 1)              //Символ конца строки выталкивает в выходную строку все символы стека
        {
            while (!s.isempty())
            {
                out[p] = s.pop();
                p++;
            }
            break;
        }
        j++;
    }
    i = 0;
    fprintf(out1, "%s\n", "Выражение в обратной польской записи:");
    while (i<p)
    {
        fprintf(out1, "%c", out[i]);
        i++;
    }
    fclose(out1);
    fclose(in1);
}
Почему компилятор ругается на fopen вот здесь:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
int main()
{
    int len = 0, j = 0, p = 0, i;
    char in[MAX], out[MAX];//Входная и выходная строки
    stack s;
    FILE *in1, *out1;
    in1 = fopen("in.txt", "r");
    out1 = fopen("out.txt", "w");
    while (!feof(in1))//Считываем входную строку из файла и ищем длину строки
    {
        fscanf(in1, "%c", &in[j]);
        j++;
        len++;
    }
и как это исправить?

 Комментарий модератора 

Xerasima, Вы создали 16 (шестнадцать) тем в разделе "С++ для начинающих". И только в трёх Вы не нарушили правил форума. Остальные 13 (тринадцать) - или нет тэгов, или название темы малоинформативно.
Убедительная просьба, не игнорировать это сообщение и ознакомится с правилами. Это не займёт у Вас много времени (я думаю, не более 5 минут). Если нам всё-таки не удастся прийти к взаимопониманию, я буду вынужден применить к Вам более жёсткие меры воздействия. Надеюсь, до этого не дойдёт.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 19:44. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru