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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.90
May
#1

Динамические массивы - C++

05.03.2009, 18:09. Просмотров 1324. Ответов 2
Метки нет (Все метки)

Помогите сделать задание пожалуйста , люди. Никак не могу понять как это оживить это...

Язык: С++

MS VS: Win32 Console Aplication


Само задание звучит примерно вот так - Сформировать одномерный динамический массив (сформировал). Используя заданное число К , производить циклический сдвиг значений массива на К позиций вправо. Использовать временный динамический массив размером К.


Ну и вот дальше... не знаю. ясно что надо что бы выглядело всё так - При К=2.. 0 элемент массива становистся первым.. а первый вторым... 2 последних элемента своевременно переносятся во временный массив.. и оттуда переносятся в новый , сдвинутый массив на место нулевого и первого. Помогите пожалуйста... я в тупике.. не знаю как это воплотить в жизнь.

Заранее спасибо!

Код
#include "stdafx.h"
#include <iostream>
#include <ctime>
#include <iomanip>
using namespace std;

int _tmain(int argc, _TCHAR* argv[])
{
int *pmas,*pres,*ptemp,diapazon,minnum,size_mas;
unsigned int r;
char cont;
do
{

        r=unsigned int (time(NULL)%32767);
		srand(r);
		cout<<"diapazon=";
		cin>>diapazon;
		cin.get();
		cout<<"min_num=";
		cin>>minnum;
		cin.get();
		cout<<"size pmas=";
		cin>>size_mas;
		cin.get();
		
		pmas=new int[size_mas];

		for(int i=0;i<size_mas;i++)
			*(pmas+i)=int (rand()/32767.*diapazon)+minnum;
		for(int i=0;i<size_mas;i++)
			cout<<pmas+i<<'\t'<<*(pmas+i)<<'\n';
			cout<<'\n';

delete [] pmas;


cout<<"For continue press <<Enter>> , for exit press any other symbol"<<endl;
		cin.get(cont);
		
	}while(cont=='\n');



	return 0;
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
05.03.2009, 18:09
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Динамические массивы (C++):

Динамические массивы и функции. Динамические массивы. - C++
Дана матрица 6х8 целого типа. Создать одномерный массив, содержащий элементы матрицы, кратные числу, введенному с клавиатуры.

Указатели и массивы. Индексация с помощью указателей. Передача массивов в функции. Динамические массивы (обработка матриц) - C++
Для каждого элемента , bij, i= 1,...,n , j=1,...,n определяется свой многоугольник местонахождением соответствующего элемента aij (см....

динамические массивы - C++
Здравствуйте, Посмотрите ,пожалуйста,задачу! ...

динамические массивы - C++
здравствуйте, посмотрите,пожалуйста, что не так с моим кодом? пробую использовать динамический массив. Но программа работает неправильно....

Динамические массивы - C++
помогите,пожалуйста,над срочно написать прогу))))буду оч благодарна)))))))) 1. Сформировать динамический одномерный массив, заполнить...

Динамические массивы - C++
1. Заданы два массива А(N) и В(M). Подсчитать в них количество отрицательных элементов и первым на печать вывести массив, имеющий...

2
accept
4825 / 3246 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
06.03.2009, 09:17 #2
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
 
#include <stdio.h>
 
#define asize(a) \
            (sizeof (a) / sizeof (a)[0]) \
                /* вычисляет длину массива */
 
void RightRotate(int *nums, unsigned size, unsigned n);
void PrintArray(int *nums, unsigned size);
 
/* вращает массив целых чисел вправо */
main()
{
    int n[] = { 1, 2, 3, 4, 5 };
 
    RightRotate(n, asize(n), 2);
    PrintArray(n, asize(n));
    return 0;
}
 
/* RightRotate:  вращает массив целых чисел nums
                 размерности size вправо n раз */
void RightRotate(int *nums, unsigned size, unsigned n)
{
    int i, tmp;
    
    nums += size-1;
    while (n-- > 0) {
        tmp = *nums;
        for (i = 0; i < size; i++)
            *(nums-i) = *(nums-i-1);
        *(nums-size+1) = tmp;
    }
}
 
/* PrintArray:  выводит массив целых чисел nums размерности size */
void PrintArray(int *nums, unsigned size)
{
    int i;
    
    for (i = 0; i < size; i++)
        printf(" %d%s", nums[i], i == size-1 ? "\n" : "");
}
0
accept
4825 / 3246 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
06.03.2009, 09:22 #3
исходник прилагаю, так как копирование не срабатывает хорошо
0
Вложения
Тип файла: zip rotate_int.zip (587 байт, 34 просмотров)
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.03.2009, 09:22
Привет! Вот еще темы с ответами:

Динамические массивы - C++
Суть задания такова. Создается динамический массив А, заполняется элементами. Затем создается массив B, куда записываются все элементы...

Динамические массивы - C++
Дана целочисленная матрица размером N. Найти сумму наименьших элементов ее нечетных строк и наибольших элементов ее четных строк. Нужно...

Динамические массивы - C++
Подскажите, как найти в одномерном динамическом массиве номер первого элемента, на котором произошла смена знака?(язык Си)

Динамические массивы... - C++
Помогите пожалуйста.... Дано матрицу размерностью N * М с произвольных многочисленных элементов. Найти элементы, которые по модулю меньше...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru