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

C++ задача с массивом - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 13, средняя оценка - 4.69
MaNia
0 / 0 / 0
Регистрация: 02.03.2012
Сообщений: 3
02.06.2012, 11:43     C++ задача с массивом #1
Сколько не старался не чего у меня с этими массивами не выходит. Вообще не как не могу поянть как решать массивы =( Помогите люди добрые.

Переставить местами наибольший отрицательный и наибольший положительный элементы вектора N. Найти их порядковые номера.

C чего вообще начинать делать её? Какие библиотеки использовать?
#include<math.h>
#include<iostream>

подойдут?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.06.2012, 11:43     C++ задача с массивом
Посмотрите здесь:

C++ Задача с массивом.
Задача с одномерным массивом C++
C++ Задача с массивом
C++ Задача с массивом
Задача с массивом C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
BoBaH26
30 / 30 / 0
Регистрация: 02.12.2010
Сообщений: 255
02.06.2012, 11:56     C++ задача с массивом #2
<iostream> подойдет для наиболее "комфортного" оформления ввода-вывода (cin>>, cout<<). <math.h> здесь необязательна. Можно использовать <time.h>, если хотите заполнить массив случайными числами, то необходима будет строка "srand(time(0));" - процедура обновления базы генерации, при условии, что подключена библиотека <time.h>. Затем, после инициализации элементов, ищешь наибольший положительный и отрицательный элементы, ну а индексы уже определить нетрудно.
MaNia
0 / 0 / 0
Регистрация: 02.03.2012
Сообщений: 3
02.06.2012, 12:08  [ТС]     C++ задача с массивом #3
Цитата Сообщение от BoBaH26 Посмотреть сообщение
<iostream> подойдет для наиболее "комфортного" оформления ввода-вывода (cin>>, cout<<). <math.h> здесь необязательна. Можно использовать <time.h>, если хотите заполнить массив случайными числами, то необходима будет строка "srand(time(0));" - процедура обновления базы генерации, при условии, что подключена библиотека <time.h>. Затем, после инициализации элементов, ищешь наибольший положительный и отрицательный элементы, ну а индексы уже определить нетрудно.
Блин я кроме iostream и math.h больше не использовал не какие библиотеки =( Можешь помочь написать хотя бы начало? Буду очень благодарен.
zitxbit
Master C/C++
 Аватар для zitxbit
86 / 738 / 75
Регистрация: 11.04.2012
Сообщений: 971
02.06.2012, 12:31     C++ задача с массивом #4
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
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <memory.h>
 
#include <iostream>
 
#define N 20
#define _SIZE 100
 
using namespace std;
 
int main()
{
    int* X = new int[N];
    memset((void*)X, 0x00, sizeof(int) * N);
 
    for (int i = 0; i < N; i++)
    {
        X[i] = rand() % (2 * _SIZE) - _SIZE;
        cout << X[i] << " ";
    }
 
    cout << endl << endl;
 
    int max_i = 0, max_j = 0;
    for (int q = 0; q < N; q++)
    {
        max_i = (abs(X[q]) < abs(X[max_i])) && 
            (X[q] < 0) ? q : max_i;
        max_j = (X[q] > X[max_j]) && 
            (X[q] > 0) ? q : max_j;
    }
 
    cout << "Min X[" << max_i << "] = " << X[max_i] 
        << " Max X[" << max_j << "] = " << X[max_j] << endl;
 
    cout << endl;
 
    int _tn = X[max_i];
    X[max_i] = X[max_j];
    X[max_j] = _tn;
 
    for (int z = 0; z < N; z++)
        cout << X[z] << " ";
    cout << endl;
 
   _getch();
}
http://liveworkspace.org/code/8731f0...ec9a4cf5f3e82f
rinat_w
89 / 85 / 4
Регистрация: 13.11.2011
Сообщений: 183
02.06.2012, 12:57     C++ задача с массивом #5
Вот поменьше кода:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include<iostream>
#include<time.h>
using namespace std;
int main(){
    int n,pmax=0,nmax=0;
    cout<<"n="; cin>>n;
    int *a=new int[n];
    srand(time(0));
    for (int i=0; i<n; i++){
        a[i]=rand()%100-50;
        cout<<a[i]<<" ";
        if (a[i]>=0 && a[i]>a[pmax]) pmax=i;
        if (a[i]<0 && a[i]>a[nmax]) nmax=i;
    }
    cout<<"\n\nNegative Max ["<<nmax<<"]="<<a[nmax]<<"\n";
    cout<<"Positive Max ["<<pmax<<"]="<<a[pmax]<<"\n\n";
    int buf=a[pmax]; a[pmax]=a[nmax]; a[nmax]=buf;
    for (int i=0; i<n; i++) cout<<a[i]<<" ";
    cout<<endl;
    system("pause");
    return 0;
}
Yandex
Объявления
02.06.2012, 12:57     C++ задача с массивом
Ответ Создать тему
Опции темы

Текущее время: 04:44. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru