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

Move to front, алгоритм на C++, error C4996: 'fopen': - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Do while поиск суммы положительных чисел http://www.cyberforum.ru/cpp-beginners/thread778308.html
Написать программу поиска суммы последовательности положительных чисел, вводимых с клавиатуры. Завершением ввода считать введенный ноль. Контрольный пример: 1 2 3 -4 5 -2 0 Результат: 11
C++ Среднее арифметическое элементов одномерного массива Задание написать программу с помощью функции , найти среднее арифметическое элементов одномерного массива . без функции я нашел, но если кого нибудь не затруднит помогите найти программу с функцией темплар.. заранее спс http://www.cyberforum.ru/cpp-beginners/thread778287.html
Цикл do while. Написать программу, которая определяет максимальное число из введенной с клавиатуры последовательности C++
Как написать программу, которая определяет максимальное число из введенной с клавиатуры последовательности положительных чисел (длина последовательности неограниченна). Ниже приведен рекомендуемый вид экрана. Определение максимального числа последовательности положительных чисел. Вводите после стрелки числа. Для завершения ввода введите ноль. -> 56 -> 75 -> 43 -> О
C++ Память распределить динамически
Задали такую задачу :память матрицы распределить динамически .Найти среднее арифметическое области заштрихованной области 1 0 0 0 0 1 1 0 0 0 1 1 1 0 0 1 1 0 0 0 1 0 0 0 0 ( 1 заштрихованная область ) Вообще не понимаю как это сделать , помогите пожалуйста Т_Т
C++ Площадь S и периметр P параллелограмма по формулам http://www.cyberforum.ru/cpp-beginners/thread778270.html
Составить программу, содержащую функцию, которая рассчитывает площадь S и периметр P параллелограмма по формулам S=ab sin альфа , P=2(a+b), где a, b – стороны параллелограмма, a,b– угол между сторонами (sin вычисляется в радианах).
C++ setjump/longjump Доброго времени суток! Занимаюсь по книге Дейтелей и встретил задание на setjump/longjump. Вот оно: При использовании setjump и longjump программа может сразу передавать управление подпрограмме ошибки из глубоко вложенной функции. К сожалению, в этом случае при разматывание стека не вызываются деструкторы автоматических объектов, которые были созданы в течение последовательных вложенных... подробнее

Показать сообщение отдельно
MAQSA
2 / 2 / 0
Регистрация: 18.04.2010
Сообщений: 119

Move to front, алгоритм на C++, error C4996: 'fopen': - C++

03.02.2013, 21:14. Просмотров 3969. Ответов 2
Метки (Все метки)

Об'ясните ошибку:
1>c:\users\admin\documents\visual studio 2012\projects\consoleapplication2\consoleapplication2\consoleapplication2.cpp(79): error C4996: 'fopen': This function or variable may be unsafe. Consider using fopen_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.

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
#include "stdafx.h"
 
#include <stdio.h>
#include <string.h>
using namespace std;
#define MEGABYTE 1024*1024
 
unsigned char word[256];
unsigned char data[MEGABYTE];
unsigned short sz = 0;
unsigned char d = 0;
unsigned int i = 0;
unsigned short j = 0;
 
unsigned short search(unsigned char l)
{
    for(j = 0; j < sz; j++)
        if(word[j] == l) return j+1;
    return 0;
}
 
void MoveToFront(unsigned int rsz)
{
    unsigned short p = 0;
    for(i = 0; i < rsz; i++)
    {
        p = search(data[i]);
        if(!p)
        {
            for(j = sz; j > 0; j--)
                word[j] = word[j-1];
            word[0] = data[i];
            sz++;
        }
        else
        {
            d = word[p-1];
            for(j = p-1; j > 0; j--)
                word[j] = word[j-1];
            word[0] = d;
        }
        data[i] = (p >= 256 ? 0 : p);
    }
}
 
void MoveToBack(unsigned int rsz)
{
    unsigned char p = 0;
    for(i = rsz - 1; i >= 0; i--)
    {
        p = word[0];
        if(!data[i])
        {
            d = word[0];
            for(j = 0; j < sz-1; j++)
                word[j] = word[j+1];
            word[sz-1] = d;
        }
        else
        {
            d = word[0];
            for(j = 0; j < data[i]-1; j++)
                word[j] = word[j+1];
            word[data[i]-1] = d;
        }
        data[i] = p;
        if(i == 0) break;
    }
}
 
int main(int argc, char *argv[])
{
    if(argc <= 3)
    {
        printf("Usage: %s TYPE IN/FILE/PATH OUT/FILE/PATH\nTYPE:\n-c \t-\tCode\n-d\t-\tDecode\n\n", argv[0]);
        return 1;
    }
   FILE * in = fopen(argv[2], "r");
    FILE * out = fopen(argv[3], "w");
    bool type = false;
    if(strcmp(argv[1], "-c") == 0) type = true;
    else if(strcmp(argv[1], "-d") == 0) type = false;
    else
    {
        printf("Usage: %s TYPE IN/FILE/PATH OUT/FILE/PATH\nTYPE:\n-c \t-\tCode\n-d\t-\tDecode\n\n", argv[0]);
        return 1;
    }
    if(type)
        while(!feof(in))
        {
            unsigned int rsz = fread(data, 1, MEGABYTE, in);
            sz = 0;
            memset(word, 0, 256);
            MoveToFront(rsz);
            fwrite(&sz, 2, 1, out);
            fwrite(word, 1, 256, out);
            fwrite(data, 1, rsz, out);
            fflush(out);
        }
    else
        while(!feof(in))
        {
            fread(&sz, 2, 1, in);
            fread(word, 1, 256, in);
            unsigned int rsz = fread(data, 1, MEGABYTE, in);
            MoveToBack(rsz);
            fwrite(data, 1, rsz, out);
            fflush(out);
        }
    fclose(in);
    fclose(out);
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru