Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 24.04.2019
Сообщений: 2

В массиве A[N] осуществите сдвиг на K<N элементов вправо без использования дополнительных массивов: найти ошибку

24.04.2019, 20:46. Показов 1253. Ответов 4

Студворк — интернет-сервис помощи студентам
Задание: В массиве A[N] осуществите сдвиг на K<N элементов вправо без использования дополнительных массивов. Первые 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
#include <iostream>
#include <time.h>
using namespace std;
 
void massiv(int *a, int n)
{
    srand(time(NULL));
    cout << "Массив: ";
    for (int i = 1; i <= n; ++i)
    {
        a[i] = rand() % 100;
        cout << a[i] << " ";
    }
    cout << endl;
}
void obr_massiv(int *a, int n, int k)
{
    for (int i = 0; i <= 1; i++)
    {
        a[0] = k;
        cout << a[i] << " ";
    }
    for (int i = 2; i <= n; i++)
        cout << a[i] << " ";
    cout << endl;
}
 
int main(int argc, char* argv[])
{
    setlocale(0, "");
    int n; int a[100]; int k; cout << "Введите кол-во элементов массива: "; cin >> n;
    massiv(a,n); 
 
    cout << "Введите сдвиг на K < N вправо: "; cin >> k;
    cout << "Обновленный массив: ";
    obr_massiv(a,n-k,k); 
 
    system("pause");
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.04.2019, 20:46
Ответы с готовыми решениями:

Удалить числа из файла, без использования дополнительных массивов и файлов
Всем привет, насколько я понимаю, само удаление из файла и не удаление вовсе, открываем файл и переписываем его в другой пропуская какую-то...

Массив: Найти среднее арифметическое элементов в окрашенной области без дополнительных массивов.
Заданная матрица целых чисел размером (N, N). найти среднее арифметическое элементов в окрашенной области. запрещено использование...

Удалить из строки все числа которые делятся на 3. (Без использования дополнительных массивов)
Вот такая вот задачка)! скажите правильно ли я её решил? и еще как мне вывести нормально как была строка)тоесть не задом наперед! ...

4
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
25.04.2019, 00:40
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
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
 
void Set(double *A, int N)
{    
    for (int i=0; i<N; i++)    
        A[i]=rand()%100;
}        
 
void Shift(double *A, int N, int k)
{
    for (int j=0; j<k; j++)
    {
    for (int i=N-1; i>0; i--)
    A[i]=A[i-1]; 
    A[j]=0.0;
    }
}
 
void Print(double *A, int N) 
{    
    for (int i=0; i<N; i++)
      cout << A[i] << " ";    
    cout << "\n";
} 
 
int main()
{
    srand((int)time(0));
    int N, k;
    cout << "N="; cin >> N;
 
    double*A = new double[N];
    
    Set(A,N);
    Print(A,N);
    cout << "Shift="; cin >> k;
    Shift(A, N, k);
    Print(A,N);
    delete[]A;
system("pause");
return 0;
}
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,531
Записей в блоге: 1
25.04.2019, 01:01
Yetty, зачем сдвигать по-одной позиции? Зачем тут два цикла?
C++
1
2
for (int i=k; i<N; ++i)
    A[i-k]=A[i];
Добавлено через 50 секунд
ой, это влево... ну вправо аналогично!

Добавлено через 1 минуту
C++
1
2
3
4
for (int i=N-k-1; i>=0; --i)
    A[i+k]=A[i];
for (int i=0; i<k; ++i)
    A[i]=0;
1
25.04.2019, 01:10

Не по теме:

Kuzia domovenok, напишите свой рабочий вариант кода

0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,531
Записей в блоге: 1
25.04.2019, 01:14
Цитата Сообщение от Yetty Посмотреть сообщение
Kuzia domovenok, напишите свой рабочий вариант кода
так написал же.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.04.2019, 01:14
Помогаю со студенческими работами здесь

Осуществите циклический сдвиг компонент заданного вектора A(N) вправо на две позиции
Осуществите циклический сдвиг компонент заданного вектора A(N) вправо на две позиции, то есть получите вектор A = (aN-1 , aN , a1 , a2 ,...

Осуществите циклический сдвиг компонент заданного вектора A(N) вправо на две позиции, то есть получите вектор A = (aN-1 , aN , a1 , a2
Осуществите циклический сдвиг компонент заданного вектора A(N) вправо на две позиции, то есть получите вектор A = (aN-1 , aN , a1 ...

Заданный двумерный массив повернуть но 90 градусов вправо без использования вспомогательных массивов
Заданный двумерный массив N*N повернуть но 90 градусов вправо. без использования вспомагательных массивов.

Осуществите циклический сдвиг компонент заданного вектора A(N) вправо на две позиции, то есть получите вектор A. Оформить и подключить модуль
Вод собственно код.Оформить и подключить модуль. const m = 19; var a: array of integer; p, q, i, n: integer; begin ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru