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

Задачи массивы( объяснение) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Кратчайший путь в графе. http://www.cyberforum.ru/cpp-beginners/thread394185.html
Такая задача: Дан ориентированный взвешенный ациклический граф. Требуется найти в нем кратчайший путь из вершины s в вершину t. Первая строка входного файла содержит четыре целых числа n, m, s и t — количество вершин, дуг графа, начальная и конечная вершина соответственно. Следующие m строк содержат описания дуг по одной на строке. Ребро номер i описывается тремя натуральными числами b_i,...
C++ Вывести слова, заканчивающиеся буквой "а" Дана строка символов. Признак конца строки "\n" (перевод строки). Строка состоит из слов, разделенных пробелами. Вывести слова, заканчивающиеся буквой "а", с порядковыми номерами этих слов в данной строке. Запрещено создавать темы с бессмысленными названиями вроде "Помогите!", "Вопрос" и т.п. Избегайте использования слишком большого количества смайлов в сообщениях в тематических разделах... http://www.cyberforum.ru/cpp-beginners/thread394175.html
C++ двумерная матрица А произвольной размерности
Пусть есть двумерная матрица А произвольной размерности. Сформировать на ее основе вектор В элементами которого является сумма элементов строк
Разработка алгоритмов и программ по реализации перегрузки операторов C++
Разработка алгоритмов и программ по реализации перегрузки операторов!!!!!!!!!!!!!! условие: Описать класс одномерный массив (вектор) целых чисел. Перегрузить следующую операцию: > уменьшить элементы вектора на заданное значение. помогите пожалуйсто кто знает....(чтобы работало в С++ -> console wizard -> C++ -> OK) Зарание спасибо
C++ Считывание из файла. http://www.cyberforum.ru/cpp-beginners/thread394159.html
в текстовом файле в несколько строк содержатся данные разных типов. Добавлено через 17 минут Необходимо подсчитать количество строк. Создать массив с такой размерностью и записать туда в каждую ячейку свою строку. Проблема с созданием массива динамического и в переписыванием строки из файла в массив. int patients() { int par=4; char c;
C++ принцип геометрического параллелизма на MPI не знаю, в какой отдел обращаться с этим вопросом, решила сюда. необходимо распараллелить такую задачку: y1=a + a*x1 + a*x2 + a*x3; y2=a + a*x1 + a*x2 + a*x3; y3=a + a*x1 + a*x2 + a*x3; y4=a + a*x1 + a*x2 + a*x3; подобрать отпимальные значения х1, х2, х3. 0< = x1<= 2 0<= x2 <=5 подробнее

Показать сообщение отдельно
ZaVyLoN
83 / 83 / 6
Регистрация: 26.10.2009
Сообщений: 269
29.11.2011, 01:29     Задачи массивы( объяснение)
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
#include <iostream>
#include <stdlib.h>
using namespace std;
 
void mas_in(int* a, int size); 
void mas_out(int* a, int size);
void sort(int* a, int size);
 
int main(int argc, char *argv[])
{
    int size;
    cout << "Enter size: ";
    cin >> size;
    int* mas = (int*)malloc(size);
 
    cout << "Enter massive: " << endl;
    mas_in(mas, size);
    cout << endl;
    
    
    cout << "Massive: " << endl;
    mas_out(mas, size);
    cout << endl;
    
 
    sort(mas, size);
    cout << "Sort Massive: " << endl;
    mas_out(mas, size);
    cout << endl;
    
    free(mas);
    mas = NULL;
    return 0;
}
void  mas_in(int* a, int size)
{
    for (int i = 0; i < size; i++) 
        cin >> a[i];
}
 
void sort(int* a, int size)
{
    int max;    
    // сортировка "метод пузырька"
    for (int i=0; i < size; i++)
    {
        for(int j = 0; j < size - i - 1; j++)
        {
            if(a[j] >= a[j + 1]) // если нужно по убыванию, меняешь знак на <
            {
                max = a[j];
                a[j] = a[j + 1];
                a[j + 1] = max;
            }
        }
        
    }
}
 
 
void mas_out(int* a, int size)
{
    for(int i=0; i < size; i++) 
        cout << "a[" << i << "] = " << a[i] << endl;
}
Если нужно макс. эл. и его индекс, тогда можно сделать вот так.
Дописать фун-цию mas_out.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
void mas_out(int* a, int size)
{
    int max = 0, index = 0;
    for(int i=0; i < size; i++) 
        cout << "a[" << i << "] = " << a[i] << endl;
    max = a[0];
    for(int i = 0; i < size; i++)
    {
        
        if(a[i] >= max)
        {
            max = a[i];
            index = i;
        }
    }
 
    cout << "Max el.: a[" << index << "] = " << max << endl;
}
Добавлено через 35 минут
Табуляция почему-то сбилась, выровняешь.
Будет читабельней и разборчивей.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru