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

Проверить код на адекватность (объединение двух упорядоченных бинарных файлов в один) - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Не могу найти ошибку в коде http://www.cyberforum.ru/cpp-beginners/thread862384.html
Не могу найти ошибку, в чем проблема? Текст задания. Несомненно, одно из самых важных и ответственных дел, которые существуют в нашем мире — это воспитание детей. Возможно, если вы будете хорошо учиться и покажете высокие результаты на этом соревновании, вас примут в детский сад нянечкой. Но вы должны быть хорошо подготовлены к принятию такой ответственной должности! Рассмотрим типичные...
C++ Winsock2 hook Может кто-нибудь написать пример хука для Winsock2(Ws2_32) closesocket ? (что бы закрывать сокет только когда нужно) http://www.cyberforum.ru/cpp-beginners/thread862378.html
C++ Перегруженный оператор сдвига '<<' не функции-члена класса для объекта ostream
Добрый день. В учебнике попалось на первый взгляд простое задание: #include <iostream> int main() { std::cout << "Hello, world!"; } нужно модифицировать программу таким образом, чтобы она выводила: Initialize Hello, world!
Поиск букв и символов в тексте C++
Привет знатокам! вот такая задача: "Дан текст, каждый символ которого может быть малой буквой, цифрой или одним из знаков "+","-","*". Группой букв будем называть такую совокупность последовательно расположенных букв, которой непосредственно не следует буква. Аналогично определим группу цифр и группу знаков. а) Подсчитать число вхождений буквы f в первые три группы букв ( в предложение, что...
C++ Вызов библиотеки классов C# из С++ http://www.cyberforum.ru/cpp-beginners/thread862357.html
Здравствуйте! Нужна помощь знающих людей. Предположим есть такая библиотека классов на C# в виде dll файла: using System; namespace ManagedDLL { public class ManagedClass { public int Add(int Number1, int Number2)
C++ Исправьте ошибку Бинарный поиск не находит числа которые находятся в первой строке матрицы. #include <iostream> #include <iomanip> #include <conio.h> using namespace std; int main () { int i, j, el, m, k, kol= 0, w, last, first, mid,c,temp,x,z; подробнее

Показать сообщение отдельно
w0nder
 Аватар для w0nder
0 / 0 / 0
Регистрация: 23.11.2012
Сообщений: 131
12.05.2013, 14:13     Проверить код на адекватность (объединение двух упорядоченных бинарных файлов в один)
Даны два бинарных файла f1 и f2, компоненты которых - произвольные цепочки символов (компоненты упорядочены в алфавитном порядке). Написать программу, которая объединяет файлы f1 и f2 в файл f3 так, чтобы компоненты f3 тоже были упорядочены (в файле f3 не должны появляться два компонента с одинаковым значением). Написать также вспомогательные программы, которые позволяют создать файлы f1 и f2 и печатают на экран содержание файла.

(Нельзя копировать все содержимое файла в оп.память.
Под компонентом файла имеется ввиду запись фиксированной длины.)


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
#include <iostream>
#include <fstream>
 
int main() {
   std::ifstream inFirst( "f1.bin", std::ios::in | std::ios::binary );
   std::ifstream inSecond( "f2.bin", std::ios::in | std::ios::binary );
   std::ofstream outThird( "f3.bin", std::ios::out | std::ios::binary );
 
   char char1;
   char char2;
 
   if (!( inFirst && inSecond && outThird ))
      return -1;
 
   inFirst.read( reinterpret_cast< char * >( &char1 ), sizeof( char1 ));
   inSecond.read( reinterpret_cast< char * >( &char2 ), sizeof( char2 ));
 
   while ( inFirst && inSecond ) {
      if ( char1 < char2 ) {
         outThird.write( reinterpret_cast < const char * >( &char1 ), sizeof( char1 ));
         inFirst.read( reinterpret_cast < char * >( &char1 ), sizeof( char1 ));
      } else {
         outThird.write( reinterpret_cast < const char * >( &char2 ), sizeof( char2 ));
         inSecond.read( reinterpret_cast < char * >( &char2 ), sizeof( char2 ));
      }
   }
 
   while ( inFirst ) {
      outThird.write( reinterpret_cast< const char * >( &char1 ), sizeof( char1 ));
      inFirst.read( reinterpret_cast< char * >( &char1 ), sizeof( char1 ));
   }
 
   while ( inSecond ) {
      outThird.write( reinterpret_cast< const char * >( &char2 ), sizeof( char2 ));
      inSecond.read( reinterpret_cast< char * >( &char2 ), sizeof( char2 ));
   }
 
   return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 00:03. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru