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

Значения элементов массива проверить на кратность 3 и результатами заполнить массив II - C++

Восстановить пароль Регистрация
 
EDWARD96
0 / 0 / 0
Регистрация: 21.07.2012
Сообщений: 3
21.07.2012, 17:36     Значения элементов массива проверить на кратность 3 и результатами заполнить массив II #1
1. Создать 3 одномерных массива одинаковой размерности.
а) I массив заполнить случайными числами в пределах от -8 до 8.
б) Значения элементов этого массива нужно проверить на кратность 3 и результатами заполнить массив II (если значение кратно 3 , то результат true, если некратно - false).
в) III массив заполнить элементами в зависимости от значений массива I (отрицательные значения массива I заменяются -1 в массиве III, положительные значения массива I заменяются 1 в массиве III и нулевые 0).

2. Добавить к предыдущему заданию:
а) Создать двумерный массив с равным количеством строк и столбцов.
б) Заполнить его значениями I и III одномерных массивов, а не достающие элементы заполняются нулями.
в) Найти среднее арифметическое обоих диагоналей двумерного массива.
г) Поменять местами значения четных и нечетных столбцов двумерного массива.

3. Добавить к предыдущему заданию:
а) Создать функции Vivid_1() и Vivod_2() вывода на экран двумерного и одномерного массивов.
б) Создать функцию Chet() вывода на экран сообщения «Кратный массив» - если во II массиве больше true, и «Некратный массив» - если во II массиве больше false.
в) Создать функцию сортировки Sort_u() по убыванию значений элементов двумерного массива.
г) Создать функцию Graf_k() вывода на экран квадратов из каждого положительного значения одномерного массива I с помощью любых символов
_________________________________________________________________________________________
вот решил сколько смог дальше пытаюсь не выходи


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
#include <iostream>
#include <time.h>
using namespace std;
void main()
{
    srand(time(0));
const int size=5;
int mass1[size];
bool mass2[size];
int mass3[size];
 
for(int i=0;i<size;i++)
    {
 mass1[i]=rand()%16-8;
    if(mass1[i]%3==0)
    {mass2[i]=true;}
    else {mass2[i]=false;}
 
    }
for(int i=0;i<size;i++)
{
        if(mass1[i]<0)
            {mass3[i]=1;
        
        }
        if(mass1[i]==0)
        {
            mass3[i]=0;
            
        }
        else {
            mass3[i]=-1;
            
        }
        
}
 
int mass2mer [size] [size];
for(int i=0;i<size;i++)
{
    mass2mer[0][i]=mass1[i];
    mass2mer[1][i]=mass3[i];
        for(int j=0;j<size;j++)
        {
            mass2mer[2][j]=0;
        }
    
}
for(int i=0;i<mass2mer;i++)
{for (int j=0;j>mass2mer;j--)
{size+size\2;}}
 
}
 Комментарий модератора 
1.
5.15 Запрещено создавать темы с множеством вопросов во всех разделах, кроме разделов платных услуг. Один вопрос - одна тема.
Правила форума
2. Используйте теги форматирования кода.
3. Определитесь с языком программирования. Если нужно на С++ - напишите, перенесу.
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
21.07.2012, 17:36     Значения элементов массива проверить на кратность 3 и результатами заполнить массив II
Посмотрите здесь:

Заполнить двумерный масив результатами таблицы умножения C++
Найти сумму модулей элементов массива после первого элемента C++
Заполнить двумерный массив Е (5*3) с клавиатуры. Найти среднее арифметическое всех элементов массива. C++
Заполнить массив B значениями элементов массива A, исключив из него повторяющиеся элементы C++
Заполнить массив, членами натурального ряда, кратным трем. Найти сумму элементов массива и их число. C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
edward_jonson
 Аватар для edward_jonson
157 / 157 / 25
Регистрация: 23.02.2011
Сообщений: 388
21.07.2012, 20:04     Значения элементов массива проверить на кратность 3 и результатами заполнить массив II #2
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Немножко подправил ваш вариант и добавил пару заданий, вам осталось - 2 г, 3 в г
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
const int size = 5;
 
void Vivod_1 (int *mass, int size)
{
    for (int i = 0; i < size; i ++) printf("%4d", mass[i]);
}
 
void Vivod_2 (int mas2[][size], int size)
{
    for (int i = 0; i < size; i ++)
    {
        for (int j = 0; j < size; j ++)
            printf("%4d",mas2[i][j]);
        printf("\n");
    }
}
 
void Chet(bool * mas, int size)
{
    int trcnt = 0, flcnt = 0;
    for (int i = 0; i < size; i ++)
        if (mas[i]) trcnt ++;
        else flcnt ++;
    if (trcnt > flcnt) printf("Kratnii massiv\n");
    else if(flcnt > trcnt) printf("Nekratnii massiv\n");
    else printf("Neitralnii massiv\n");
}
 
int main()
{
    srand(time(0));
 
    int mass1[size];
    bool mass2[size];
    int mass3[size];
 
    for (int i = 0; i < size; i ++)
    {
        mass1[i] = rand()%17-8;
        if(mass1[i]%3 == 0) mass2[i] = true;
        else mass2[i] = false;
 
        if(mass1[i] < 0) mass3[i] = 1;
        else if(mass1[i] == 0) mass3[i] = 0;
        else mass3[i] = -1;
    }
 
    printf("mass1: ");
    Vivod_1(mass1,size);
    printf("\n");
 
    printf("\nmass2: ");
    for (int i = 0; i < size; i ++)
        mass2[i] ? printf("true ") : printf("false ");
    printf("\n");
    Chet(mass2, size);
 
    printf("\nmass3: ");
    Vivod_1(mass3,size);
    printf("\n\n");
 
    int mass2mer [size] [size];
    for (int i = 0; i < size; i ++)
    {
        mass2mer[0][i] = mass1[i];
        mass2mer[1][i] = mass3[i];
        for(int k = 2; k < size; k ++)
            for(int j = 0; j < size; j ++)
                mass2mer[k][j] = 0;
    }
 
    printf("mass2mer:\n");
    Vivod_2(mass2mer,size);
 
    double avMajD = 0.0, avMinD = 0.0;
    for (int i = 0; i < size; i ++)
        for (int j = 0; j < size; j ++)
        {
            if (i == j)
                avMajD += (double)mass2mer[i][j];
            if (i == size - j - 1)
                avMinD += (double)mass2mer[i][j];
        }
    avMajD /= size;
    avMinD /= size;
    printf ("average of major diagonal = %.2lf\n", avMajD);
    printf ("average of minor diagonal = %.2lf\n", avMinD);
 
 }
EDWARD96
0 / 0 / 0
Регистрация: 21.07.2012
Сообщений: 3
21.07.2012, 20:11  [ТС]     Значения элементов массива проверить на кратность 3 и результатами заполнить массив II #3
спасибо за помощь)))
а что обозначает ("%4d")
edward_jonson
 Аватар для edward_jonson
157 / 157 / 25
Регистрация: 23.02.2011
Сообщений: 388
21.07.2012, 21:19     Значения элементов массива проверить на кратность 3 и результатами заполнить массив II #4
это просто для форматирования вывода, 4 - отступ, d - для типа int
EDWARD96
0 / 0 / 0
Регистрация: 21.07.2012
Сообщений: 3
24.07.2012, 19:38  [ТС]     Значения элементов массива проверить на кратность 3 и результатами заполнить массив II #5
а вы можете мне расталковать код!

Добавлено через 2 часа 18 минут
edward_jonson, подскажите что обозначает эта строчка
C++
1
 mass2[i] ? printf("true ") : printf("false ");
Endiff
 Аватар для Endiff
30 / 30 / 1
Регистрация: 19.05.2012
Сообщений: 67
24.07.2012, 20:01     Значения элементов массива проверить на кратность 3 и результатами заполнить массив II #6
EDWARD96, тернарный оператор, по типу if-else. Все что до вопросительного знака - логическое выражение. После вопросительного знака - если условие истинно, после двоеточия - ложно.
"если ? то : иначе"
Yandex
Объявления
24.07.2012, 20:01     Значения элементов массива проверить на кратность 3 и результатами заполнить массив II
Ответ Создать тему
Опции темы

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