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

Пояснения кода - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Написать функцию, которая удаляет все лишние пробелы http://www.cyberforum.ru/cpp-beginners/thread854321.html
Доброго дня суток. Помогите пожалуйста.. Нужно написать функцию, которая удаляет все лишние пробелы, т. е. из нескольких подряд идущих пробелов оставить только один. А также есть такой код: #include "stdafx.h" #include <cmath>
C++ Сортировка Шелла В алфавитном порядке по фамилии алгоритмом Шелла #include <iostream> #include <string> #include <fstream> #include <iomanip> using namespace std; ifstream in("input.txt"); ofstream out("output.txt"); http://www.cyberforum.ru/cpp-beginners/thread854282.html
RSA шифрование C++
Народ помогите пожалуйста! Вот функция генерации ключей, вот только то нормально шифрует и расшифровывает, то криво, в чем проблема? keys kluch(Random^ rnd) { keys kl; int p, q, n, e, d, fn; Boolean rd = false; do { do {
Наследование чисто вируальной функции C++
Доброго времени суток. Пишу класс описывающий структуру файла. Имею класс relHeader c 2 чисто виртуальными функциями. Ее наследуют еще 3 класса, но при попытке реализации этих функций через классы-потомки получаю ошибку, о том что использование наследуемых функций не допускается. Почему? Как мне быть? Добавлено через 2 минуты Прошу прощения, поторопился, не объявил их в классах-потомках....
C++ итое простое число http://www.cyberforum.ru/cpp-beginners/thread854263.html
Нужно найти N-ое простое число. (1 <= N <= 10^7). Вопрос состоит в том, как эту задачу можно решать. Только блочным решетом, асимптотика O(n log ( log (n))) ?? ограничение времени на тест: 2 сек. ограничение памяти на тест: 65536 KB. По памяти должно влезть ?? Есть ли другой способ решения ? Мой старый прекальк 10^7 простых чисел не влезает в размер решения :D 90 Мегабайт текста :D ...
C++ случайная фраза нужна программа, которая будет считывать текст из файла и выводить одно случайное слово. если не трудно помогите пожалуйста подробнее

Показать сообщение отдельно
kura007
1 / 1 / 0
Регистрация: 02.12.2012
Сообщений: 17
02.05.2013, 18:20     Пояснения кода
Вариант 5. Сформировать одномерный массив. Удалить из него K элементов, начиная с заданного номера, добавить K элементов, начиная с заданного номера.

объясните пожалуйста отмеченные мною части кода.. Буду благодарен.

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
#include "stdafx.h"
#include <iostream>
#include <conio.h>
#include <time.h>
#include <locale>
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "Russian");
    int *mas,size,num,K,temp,numb;
    cout<<"Введите размерность массива:";
    cin>>size;
    mas=(int*)malloc(size*sizeof(int));
    srand(time(0));
    for (int i=0; i<size; i++)
    {
        mas[i]=rand()%20;
    }
    cout<<"Исходный массив:";
    for (int i=0; i<size; i++)
    {
        cout<<mas[i]<<" ";
    }
    cout<<endl;
    cout<<"Введите сколько элементов удалить:";
    cin>>K;
    cout<<"Начиная с какого номера:";
    cin>>num;
    int num1=num;
    for (int i=0; i<K; i++)                                 
    {
        for (int j=num; j<size; j++)          
        {
            temp=mas[j+1];
            mas[j+1]=mas[j];
            mas[j]=temp;
        }
    }
    cout<<endl;
    mas=(int*)realloc(mas,(size-K)*sizeof(int));
    cout<<"Массив после удаления элементов:";
    for (int i=0; i<size-K; i++)
    {
        cout<<mas[i]<<" ";
    }
    cout<<endl;
    mas=(int*)realloc(mas,(size+K)*sizeof(int));
    cout<<"С какого номера добавить элементы:";
    cin>>numb;
    for ( int i=size-K; i<size; i++)
    {
        mas[i]=mas[numb];
        numb++;
    }
    for (int i=size-1; i>num1+K; i--)
        for (int j=K-1; j>=0; j--)
            swap(mas[i-j],mas[i-j-1]);
    cout<<"Массив после добавления элементов:";
    for (int i=0; i<size; i++)
    {
        cout<<mas[i]<<" ";
    }
    cout<<endl;
    free (mas);
    getch();
    return 0;
}
C++
1
2
3
4
5
6
7
8
9
for (int i=0; i<K; i++)                                 
    {
        for (int j=num; j<size; j++)          
        {
            temp=mas[j+1];
            mas[j+1]=mas[j];
            mas[j]=temp;
        }
    }
C++
1
mas=(int*)realloc(mas,(size+K)*sizeof(int));
C++
1
swap(mas[i-j],mas[i-j-1]);
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 10:04. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru