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

C++ Изменение порядка байтов в файле - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Построить результат сглаживания заданной вещественной матрицы размером 10 на 10 http://www.cyberforum.ru/cpp-beginners/thread83782.html
:cry: Помогите пожалуйста, написать программу в с++. А то я чайник, ничего не понимаю... Соседями элемента А с индексом ij в матрице назовем элементы A с индексом kl c i - 1 <= k <= i+1, j-1<=l<=j+1, (k,l) не =(i,j). Операция сглаживания матрицы дает новую матрицу того же размера, каждый элемент который получается как среднее арифметическое имеющихся соседей соответствующего элемента исходной...
C++ Массив, матрица и замена букв Помогите пожалуйста с решением задач. Спасибо за ранее!!! 1) В целочисленном массиве заменить max и min средним арифметическим оставшихся чисел. 2) В квадратной матрице размерности N поменять min элемент в столбце и элемент на побочной диагонали. 3) В текстовом файле поменять большие буквы на маленькие и наоборот. http://www.cyberforum.ru/cpp-beginners/thread83780.html
C++ Поразрядная сортировка
Необходимо реализовать метод поразрядной сортировки. Нужно отсортировать последовательность так, что бы она была отсортирована в порядке спадания величины. Вот в чём эта сортировка заключается: Пусть у нас есть есть последовательность двоцифровых натуральных чисел. Заведём 10 очередей, в которые будем складывать наши числа независимо от того, какая в них последняя цифра. Дальше соберём все со...
Не компилится! C++
Здравствуйте. Подскажите ошибки пожалуйста. Задание: Написать рекурсивную функцию, которая принимает массив и размер массива, а возвращает наименьший элемент массива. #include <vcl.h> #include <iostream.h> #include <conio.h> #include <stdlib.h> #include <stdio.h> #pragma hdrstop
C++ Найти ошибки (двумерные массивы) http://www.cyberforum.ru/cpp-beginners/thread83770.html
Элемент матрицы называется локальным минимумом, если он строго меньше всех имеющихся у него соседей. Подсчитать количество локальных минимумов заданной матрицы 10 на 10 . Найти сумму модулей элементов выше главной диагонали. Вопрос по первой части : 1)Что-то он криво считает минимумы в углах там вроде как нужен учёт границ только я не знаю как это сделать (( и ещё с элементами меньше нуля...
C++ Поиск самых коротких расстояний между любыми двумя вершинами графа по методу Шимбела у меня большие проблемы с логикой программирования) поэтому обращаюсь к вам за помощью..... Поиск самых коротких расстояний между любыми двумя вершинами графа по методу Шимбела. подробнее

Показать сообщение отдельно
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9371 / 5421 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
08.01.2010, 23:44     C++ Изменение порядка байтов в файле
На С вот:
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
#include <stdio.h>
#include <stdlib.h>
 
/* возвращает массив задом на перёд */
char *bufReverse(char *buf, size_t cnt){
    char *h, *t, c;
    
    if ( !buf || !cnt )
        return NULL;
    for ( h = buf, t = buf + cnt - 1; h < t; ++h, --t ){
        c = *h;
        *h = *t;
        *t = c;
    }
    return buf;
}
 
/*
    составить программу, изменяющую порядок байтов в файле на реверсный
    (последний байт становится первым, первый - последним)
*/
int main(int argc, char **argv){
    char *buf;
    long len;
    FILE *fin, *fout;
    
    if ( argc < 3 ){
        fprintf(stderr, "Usage: %s <input_file> <output_file>\n", *argv);
        exit(1);
    }
    if ( ( fin = fopen(argv[1], "rb") ) == NULL ){
        fprintf(stderr, "Can't open file <%s> for input!\n", argv[1]);
        exit(1);
    }
    fseek(fin, 0, SEEK_END);
    len = ftell(fin);
    if ( len < 0 ){
        fprintf(stderr, "Can't read input file!\n");
        exit(1);
    }
    rewind(fin);
    if ( ( buf = (char*)malloc(len) ) == NULL ){
        fprintf(stderr, "Memory error!\n");
        exit(1);
    }
    if ( fread(buf, 1, len, fin) != len ){
        fprintf(stderr, "Can't read input file!\n");
        exit(1);
    }
    fclose(fin);
    
    if ( ( fout = fopen(argv[2], "wb") ) == NULL ){
        fprintf(stderr, "Can't open file <%s> for output!\n", argv[2]);
        exit(1);
    }
    if ( fwrite(bufReverse(buf, len), 1, len, fout) != len ){
        fprintf(stderr, "Can't write to output file!\n");
        exit(1);
    }
    fclose(fout);
    
    free(buf);
    exit(0);
}
А на С++ по той же логике, но другими методами
 
Текущее время: 21:22. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru