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

С++ ВАЖНО. тяжело - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Массив в С++ http://www.cyberforum.ru/cpp-beginners/thread318756.html
Задан двухмеpный массив, содеpжащий n стpок и m столбцов. Получить из него новый массив той же pазмеpности путем деления каждого элемента исходного массива на сумму элементов стpоки, в котоpой он находится.
C++ Массив в С++ ВАЖНО Заданы два одномеpных массива X и Y, содеpжащие кооpдинаты N точек на плоскости. Опpеделить, сколько точек попадет внутpь окpужности с центpом в точке XO, YO и pадиусом R. http://www.cyberforum.ru/cpp-beginners/thread318755.html
C++ Разница между массивом структур и очередью
Поясните пожалуйста разницу между массивом структур и очередью.
C++ Игра на C++
Нужно написать какую-небуть не особо сложную игру на C++. В голову приходять разные арканоиды/танчики/бомбермены, но для них, насколько я понимаю, нужно знать OpenGL. Можно ли написать игру без OpenGL? Если нет, то можно ли освоить OpenGL на нужном уровне за 2 недели? Если да, то посоветуйте литературу почитать
C++ Структура и бинарное дерево. http://www.cyberforum.ru/cpp-beginners/thread318739.html
Задача такая: На междугородной телефонной станции картотека абонентов, содержащая сведения о телефонах и их владельцах, организована как двоичное дерево. Составить программу, которая: 1) обеспечивает начальное формирование картотеки в виде двоичного дерева; 2) производит вывод всей картотеки; 3) вводит номер телефона и время разговора; 4) выводит извещение на оплату телефонного...
C++ Переключение раскладки на Windows XP Доброго времени суток! Столкнулся с очень интересным глюком: есть программа A и программа B. Программа B запускает программу A через CreateProcess и висит в памяти до ее завершения, в цикле делая GetExitCodeProcess. Так вот, если запускать программу A просто так, то все нормально, а если запускать ее через программу B, то раскладка не меняется никак. Данный баг присутствует только на Windows... подробнее

Показать сообщение отдельно
Nameless One
Эксперт С++
5769 / 3418 / 255
Регистрация: 08.02.2010
Сообщений: 7,444
13.06.2011, 15:43     С++ ВАЖНО. тяжело
Код
[nameless@desktop cpp]$ ./comments sample.pas
File sample.pas contents:
----------------------------------------------
const
  len = 26;
 
  {Это символы для выбора столбца таблицы}
  alpha_hor: string = 'abcdefghijklmnopqrstuvwxyz';
 
  {Здесь будут символы для выбора строки таблицы}
  alpha_ver: string = '';
 
var
  {Это собственно таблица кодирования}
  table: array[1 .. len, 1 .. len] of char;
 
{функция получает строку S и возвращает строку,
  полученную из исходной сдвигом на N позиций}
function shift(s: string; n: integer): string;
  begin
    s := copy(s, length(s) - pred(n), n) + s;
    delete(s, length(s) - pred(n), n); shift := s
  end;
 
var
  i, j, row, col: integer;
  s: string; ch: char;
 
  key: string;
  is_russian: boolean;
  f_in: file of char; f_out, f_key: text;
begin
  { Заполнение таблицы кодировки }
  for i := 1 to len do begin
    {получаем строку символов для текущей строки таблицы}
    s := shift(alpha_hor, pred(i));
    for j := 1 to len do
      table[i, j] := s[j];
    {
      не забываем первый символ заносить в "хранилище"
      для выбора строк по кодируемой букве
    }
    alpha_ver := alpha_ver + s[1]
  end;
 
  { связываем логические файлы программы с физическими файлами на диске }
 
  { файл с фразой для кодирования - открываем для чтения }
  assign(f_in, 'f_00in.txt');
  {$i-} reset(f_in); {$i+}
 
  { файл для сохранения результата - открываем для записи }
  assign(f_out, 'f_00out.txt');
  {$i-} rewrite(f_out); {$i+}
 
  {
    файл, содержащий ключевое слово - открываем для чтения,
    считываем слово в строковую переменную и закрываем файл
  }
  assign(f_key, 'f_00key.txt');
  {$i-} reset(f_key); {$i+}
  readln(f_key, key);
  close(f_key);
 
  { счетчик закодированных символов }
  i := 0;
  {до конца кодируемого файла делаем следующее:}
  while not eof(f_in) do begin
    { читаем очередной символ }
    read(f_in, ch);
    { находим по нему строку таблицы }
    row := pos(ch, alpha_ver);
    {
      эта переменная содержит значение успеха предыдущей операции
      (если True, то символ присутствует в таблице, иначе False)
    }
    is_russian := (row > 0);
    if is_russian then begin
      { Если символ присутствует в таблице, его надо кодировать }
 
      { увеличиваем счетчик закодированных символов }
      inc(i);
 
      {
        находим столбец по значению ключевого символа
        (операция mod используется, чтобы исключить выход
        за пределы ключа, т.к. длина ключа обычно меньше
        длины шифруемой последовательности)
      }
      col := pos(key[i mod (length(key))], alpha_hor);
      { и заменяем простой символ на зашифрованный (из таблицы) }
      ch := table[row, col];
    end;
    {
      если символ надо было шифровать, он уже зашифрован,
      если он не может быть зашифрован, он остался без изменений.
      Пишем его в выходной файл
    }
    write(f_out, ch)
  end;
 
  { И закрываем оба файла: исходный и зашифрованный }
  close(f_out);
  close(f_in)
end.
----------------------------------------------

Это символы для выбора столбца таблицы
Здесь будут символы для выбора строки таблицы
Это собственно таблица кодирования
функция получает строку S и возвращает строку,
  полученную из исходной сдвигом на N позиций
 Заполнение таблицы кодировки 
получаем строку символов для текущей строки таблицы

      не забываем первый символ заносить в "хранилище"
      для выбора строк по кодируемой букве
    
 связываем логические файлы программы с физическими файлами на диске 
 файл с фразой для кодирования - открываем для чтения 
$i-
$i+
 файл для сохранения результата - открываем для записи 
$i-
$i+

    файл, содержащий ключевое слово - открываем для чтения,
    считываем слово в строковую переменную и закрываем файл
  
$i-
$i+
 счетчик закодированных символов 
до конца кодируемого файла делаем следующее:
 читаем очередной символ 
 находим по нему строку таблицы 

      эта переменная содержит значение успеха предыдущей операции
      (если True, то символ присутствует в таблице, иначе False)
    
 Если символ присутствует в таблице, его надо кодировать 
 увеличиваем счетчик закодированных символов 

        находим столбец по значению ключевого символа
        (операция mod используется, чтобы исключить выход
        за пределы ключа, т.к. длина ключа обычно меньше
        длины шифруемой последовательности)
      
 и заменяем простой символ на зашифрованный (из таблицы) 

      если символ надо было шифровать, он уже зашифрован,
      если он не может быть зашифрован, он остался без изменений.
      Пишем его в выходной файл
    
 И закрываем оба файла: исходный и зашифрованный 
[nameless@desktop cpp]$
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
#include <iostream>
#include <fstream>
#include <cstdlib>
#include <cstring>
 
int main(int argc, char* argv[])
{
    if(argc != 2)
    {
    std::cerr << "Usage: " << *argv << " FILE" << std::endl;
    return 1;
    
    }
    
 
    std::ifstream ifs(argv[1]);
 
    if(!ifs)
    {
    std::cerr << "Can't open file " << argv[1] << std::endl;
    return 1;
    }
 
    std::cout << "File " << argv[1] << " contents:" << std::endl;
    std::cout << "----------------------------------------------" << std::endl;
    
    std::filebuf* pbuf = ifs.rdbuf();
    std::cout << pbuf << std::endl;
 
    size_t size = pbuf->pubseekoff(0, std::ios::end, std::ios::in);
    pbuf->pubseekpos(0, std::ios::in);
 
    char* buffer = new char[size];
 
    pbuf->sgetn(buffer, size);
 
    char *cbeg, *cend;
    
    cbeg = strchr(buffer, '{');
 
    std::cout << "----------------------------------------------" << std::endl;
    std::cout << std::endl;
    
    while(cbeg)
    {
    cend = strchr(cbeg, '}');
    if(!cend)
        break;
 
    fwrite(cbeg + 1, sizeof(char), cend - cbeg - 1, stdout);
    putchar('\n');
    cbeg = strchr(cbeg + 1, '{');
    }
    
    delete[] buffer;
    
    return 0;
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru