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

как в файл с динамическим массивом вставить 2 старших байта первого элемента в конец файла,а 2 младших байта в середину файла - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Сформировать файл, в котором хранится информация о... http://www.cyberforum.ru/cpp-beginners/thread725414.html
Люди помогите как написать эту программу в c++?: Сформировать файл, в котором хранится информация о заболеваниях сотрудников: ФИО., Год рождения, заболевания, продолжительность болезни. На его основе сформировать список сотрудников постарше 30 лет Оригинал: Сформувати файл, в якому зберігається інформація про захворювання співробітників: ПІБ., рік народження, захворювання, тривалість...
C++ определить количество слов в которых одинакова первая и последняя буквы мне нкжно определить количество слов в которых одинакова первая и последняя буквы я попыталась но ничего не получается((( #include <iostream> #include <conio.h> #include <string.h> using namespace std; char main() { setlocale(LC_ALL,"Rus"); http://www.cyberforum.ru/cpp-beginners/thread725411.html
C++ массив Ocenki
Помогите пожалуйста решить задачу!!!Очень нужна,а сама не разбираюсь((((( Имеется массив Ocenki, состоящий из N (Л^> 2) судейских оценок (каждая оценка положительна). В некоторых видах спорта принято отбрасывать самую большую и самую маленькую оценки, чтобы избежать влияния необъективного судейства, а в зачет спортсмену идет среднее арифметическое из оставшихся оценок. Решим эту задачу,...
Вычислить сумму элементов C++
Задача на ряд Тейлора, не могу сделать
C++ Разработать класс определяющий кривую линию Кассини http://www.cyberforum.ru/cpp-beginners/thread725385.html
http://yadi.sk/d/X7xjPdvy1877m Заранее спасибо! Перепишите задание на форум. По правилам запрещено выкладывать задание в виде картинке Добавлено через 12 часов 55 минут Разработать класс определяющий кривую линию Кассини Линия Кассини – геометрическое место точек M, для которых произведение MF1*MF2=a^2 расстояний до концов данного отрезка F1F2=2с равно квадрату данного отрезка a....
C++ Связный список (Используя структуру описания даты, построить связный список студентов, сформированный в алфавитном порядке) Здраствуйте! Помогите пожалуйста найти косяк. Выводится только первая строчка из списка студентов. Вот такая задачка : Программа формирования списка студентов. Используя структуру описания даты, построить связный список студентов НГТУ, сформированный в алфавитном порядке. При введении даты рождения и даты поступления осуществлять контроль правильности ввода дат. #include <stdio.h> ... подробнее

Показать сообщение отдельно
Alcomy
Сообщений: n/a

как в файл с динамическим массивом вставить 2 старших байта первого элемента в конец файла,а 2 младших байта в середину файла - C++

09.12.2012, 21:39. Просмотров 261. Ответов 0
Метки (Все метки)

нужно в файл с динамическим массивом вставить 2 старших байта первого элемента в конец файла,а 2 младших байта в середину файла, но почему то все 4 байта он записывает в конец файла, не могу понять в чем ошибка
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
#include <fstream>
#include <iomanip>
#include <stdio.h>
#include <iostream>
using namespace std;
int row, col;
int main(int argc, char* argv[])
{
    int i ,j ,k ,z, a;
    ifstream ifs("D:\input.txt");
    ifs >> row >> col;
    float ** pt = new float * [row];
    for (int i = 0; i < row; i++, cout << endl)
    {
        pt[i] = new float [col];
        for ( j = 0; j < col; j++) 
        {
            ifs >> pt[i][j];
        }
    }
    
    for (i=0; i < row ; i++,cout  << endl)
    {
        for (j=0; j<col; j++)
        {
            cout << setw(4) <<setprecision(3) << pt[i][j] << "   ";
 
        }
        cout << endl;
    }
    cout << endl;
    cout << endl;
    cout << endl;
 
    
    FILE *pf, *pff;
    long size = 0;
 
    if ((pf=fopen("D:\input.txt", "rb"))==NULL)
    {
        puts("ERROR\n");
        exit(1);
    }
    else
    {
        fseek (pf, 0, SEEK_END);
        size = ftell(pf);
        fclose (pf);
    }
    unsigned char *el;
    a=int(pt[0][0]);
    el= (unsigned char*)&a;
    long middle = size/2;
 
    printf("a= 0x %02x %02x %02x %02x  \n", el[3], el[2],el[1], el[0]);
    cout << size << endl;
 
    if ((pff=fopen("D:\input.txt", "a+b"))==NULL)
    {
        puts("ERROR\n");
        exit(1);
    }
    else
    {
        fseek (pff, 0, SEEK_END);
        fprintf( pff, " %02x %02x\n", el[3], el[2] );
        fseek (pff, middle,SEEK_SET );
        fprintf( pff, " %02x %02x\n", el[1], el[0] );
        fclose (pff);
    }
 
    for (int i = 0; i < row; i++) delete[] pt[i];
    delete[] pt;
    cin.get();
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 15:52. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru