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

Непонятная функция в коде - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Вычислить периметр и площадь треугольника по заданным координатам его вершин http://www.cyberforum.ru/cpp-beginners/thread1149822.html
Помогите решить задачу! Вычислить периметр и площадь треугольника по заданным координатам его вершин.
C++ Подсчитать количество вхождений каждого символа в строку например у Вас есть строка: asddsg В выходной файле, куда Вы запишите результаты работы программы будет: a – 1 s – 2 d – 2 g – 1 http://www.cyberforum.ru/cpp-beginners/thread1149809.html
Вычислить сумму ряда с погрешностью C++
вычислить сумму ряда с погрешностью е=0,0001 в окрестности точки ноль,т.е при >1: y=sin(2x)=2x-8x в кубе /3!+32x в 5 степени /5 \! - 128x в 7 степени /7!+... кто может помогите !!!:cry:
C++ Задача на факториал. Вычислить значение выражения
Д.День. Помогите решить задачу в СИ++, неделю уже мучаюсь, надо для зачета по программированию. Вычислить значение выражения: y=(6!-25x)/(1+5!-24x)/(2+(4!-23x)/(3+(3!-22x)/(4+(2!-2x)/(5+x)))))...
C++ Закрытое хеширование с двойным опробованием http://www.cyberforum.ru/cpp-beginners/thread1149788.html
Помогите, пожалуйста! Очень нужна ХЕШ-функция с двойным хешированием. В интернете информации очень мало, ни одного примера. Реализация на С++. Заранее спасибо.
C++ Найти количество элементов этой последовательности, кратных числу K1 и не кратных числу K2 Надо решить задачи используя все типы циклов (for, while, do while). Помогите пожалуйста буду очень признателен. Задачи: 1. Дана последовательность из n целых чисел. Найти количество элементов... подробнее

Показать сообщение отдельно
sector666
0 / 0 / 0
Регистрация: 30.03.2014
Сообщений: 8

Непонятная функция в коде - C++

16.04.2014, 07:28. Просмотров 248. Ответов 3
Метки (Все метки)

Вопрос всего 1 что это за функция? vector<SMatrixNoParallelogram> MatrixNoParallelogram;

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
// Функция шифрования перестановочным шифром
AnsiString MOVETXT(AnsiString Text,int MOVETXTdx,bool ynConstCount)
{
 if(Text.Length()==0)  // Проверка на существование текста подлежащего шифрованию
  {
  return ""; // Отсутствие шифрованного текста
  }
 AnsiString text_w=""; // Временная переменная для избавления пробелов 
в шифруемом тексте
 for(int i = 0;i<Text.Length();i++) // Цикл избавления от пробелов
  {
  if(Text.c_str()[i]!=' ') // Проверка на пробел
    {
    text_w=text_w+Text.c_str()[i]; // Добавление символа
    }
  }
 Text=text_w; // Получаем текст без пробелов
 AnsiString SHIFR=""; // Будущий шифр
 vector<SMatrixNoParallelogram> MatrixNoParallelogram; // Неправильная матрица символов
 for(int i=0;i<MOVETXTdx;i++) // Цикл создания столбцов неправильной матрицы
  {
  MatrixNoParallelogram.push_back(OMatrixNoParallelogram); // Добавить столбец в неправильную матрицу
  }
 int number_column=0; // Номер текущего столбца матрицы
 for(int i=0;i<Text.Length();i++) // Цикл заполнения матрицы символами
  {
  if(number_column>=MOVETXTdx) // Проверка правильности номера столбца матрицы
    {
    number_column=0; // Возвращение на первый столбец матрицы
    }
MatrixNoParallelogram[number_column].Symvol.push_back(Text.c_str()[i]); 
// Добавление символа в матрицу
  number_column++; // Переход на следующий столбец матрицы
  }
 if(ynConstCount)  // На какие блоки разбивать шифр
  {
  int CountMaxLines=(MatrixNoParallelogram[0].Symvol.size()); 
// Максимальное количество строчек в матрице
  int NumberSymvolToBlock=0; // Номер символа записываемого в зашифрованный блок
  for(int s_MOVETXT=0; s_MOVETXT<MatrixNoParallelogram.size(); s_MOVETXT++)  // Цикл шифрования текста
    {
    for(int i_MOVETXT=0; (i_MOVETXT<(MatrixNoParallelogram[s_MOVETXT].Symvol.size())); i_MOVETXT++) // Цикл прохождения по столбцу матрицы
      {
SHIFR=SHIFR+(MatrixNoParallelogram[s_MOVETXT].Symvol[i_MOVETXT]); // Добавление нового зашифрованного символа
    NumberSymvolToBlock++; // Переход на следующий символ зашифрованного блока
    if(CountMaxLines<=NumberSymvolToBlock) // Проверка правильности номера символ зашифрованного блока
        {
     NumberSymvolToBlock=0; 
// Переход на первый символ зашифрованного блока
     SHIFR=SHIFR+" "; // Разбиение на зашифрованные блоки
        }
      }
    }
  if(NumberSymvolToBlock>0) // Хватило ли символов на последний блок
    {
   for(int s_MOVETXT=0;s_MOVETXT<(CountMaxLines-NumberSymvolToBlock);s_MOVETXT++) // Добавление символов в последний блок
      {
    SHIFR=SHIFR+"x"; // Добавление специального символа X
      }
    }
  }
 else
  {
  for(int s_MOVETXT=0; s_MOVETXT<MatrixNoParallelogram.size(); s_MOVETXT++)  // Цикл шифрования текста
    {
  for(int i_MOVETXT=0; (i_MOVETXT<(MatrixNoParallelogram[s_MOVETXT].Symvol.size())); i_MOVETXT++) // Цикл прохождения по столбцу матрицы
      {
SHIFR=SHIFR+(MatrixNoParallelogram[s_MOVETXT].Symvol[i_MOVETXT]); // Добавление нового зашифрованного символа
      }
   SHIFR=SHIFR+" "; // Разбиение на зашифрованные блоки
    }
  }
 return SHIFR; // Возвращение шифра
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru