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

Помогите с задачками на C++ - C++

Восстановить пароль Регистрация
 
Demortuus
1 / 1 / 0
Регистрация: 25.10.2010
Сообщений: 11
08.12.2011, 20:32     Помогите с задачками на C++ #1
в последней чет еще было про динамическое выделение памяти... :\

lab3
Даны натуральные числа п, а1 ..., an. Получить среднее арифметическое тех членов последовательности а1, ..., an, которые:
1) являются удвоенными нечетными числами;
2) при делении на 7 дают остаток 1, 2 или 5.
з.ы.тут собственно сами условия интересуют



lab5
Дан вещественный массив А[N][N]. Заменить: столбец, в котором находится наименьшее количество четных чисел, элементами побочной диагонали; столбец, в ко-тором находится наибольшее количество четных чисел, элементами главной диагонали.
з.ы.и тут тоже..



lab6
Дан вещественный массив А[N][М], все элементы которого различны. В каждой строке найти элемент с наименьшим значением, а затем среди найденных элементов выбрать наибольший. Вывести на экран индексы этого элемента.

заранее спасибо..
 Комментарий модератора 
Запрещено создавать темы с множеством вопросов во всех разделах, кроме разделов платных услуг. Один вопрос - одна тема.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Demortuus
1 / 1 / 0
Регистрация: 25.10.2010
Сообщений: 11
27.12.2011, 12:06  [ТС]     Помогите с задачками на C++ #2
хелп ми фиш...
dimcoder
Полярный
 Аватар для dimcoder
449 / 422 / 66
Регистрация: 11.09.2011
Сообщений: 1,108
27.12.2011, 12:13     Помогите с задачками на C++ #3
Цитата Сообщение от Demortuus Посмотреть сообщение
являются удвоенными нечетными числами;
C++
1
if ((i / 2) % 2 != 0)
Цитата Сообщение от Demortuus Посмотреть сообщение
при делении на 7 дают остаток 1, 2 или 5.
C++
1
if (x % 7 == 1 ||x % 7 == 2 || x % 7 == 5)
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
27.12.2011, 12:57     Помогите с задачками на C++ #4
Цитата Сообщение от Demortuus Посмотреть сообщение
lab3
Даны натуральные числа п, а1 ..., an. Получить среднее арифметическое тех членов последовательности а1, ..., an, которые:
1) являются удвоенными нечетными числами;
2) при делении на 7 дают остаток 1, 2 или 5.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include <iostream>
 
int main()
{
    int sum = 0;
    int count = 0;
    int x;
    while(std::cin >> x)
        if(((x & 3) == 2) && ((x % 7 == 1) || (x % 7 == 2) || (x % 7 == 5)))
        {
            sum += x;
            ++count;
        }
    std::cout << ((count) ? (sum / count) : (0)) << std::endl;
    return 0;
}
Добавлено через 30 минут
Цитата Сообщение от Demortuus Посмотреть сообщение
Дан вещественный массив А[N][N].... четных чисел.
Может все-таки целый?
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
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <iomanip>
 
int main()
{
    srand(time(NULL));
    const int rows = 5;
    const int cols = 5;
    
    int **arr = new int* [rows];
    for(int i = 0; i < rows; ++i)
    {
        arr[i] = new int [cols];
        for(int j = 0; j < cols; ++j)
        {
            arr[i][j] = rand() % 21;
            std::cout << std::setw(6) << arr[i][j];
        }
        std::cout << std::endl;
    }
    std::cout << std::endl;
    
    int maxEven = 0;
    int posMaxEven = 0;
    int minEven = rows;
    int posMinEven = 0;
    
    for(int j = 0; j < cols; ++j)
    {
        int tmp = 0;
        for(int i = 0; i < rows; ++i)
            if(!(arr[i][j] & 1))
                ++tmp;
                
        if(tmp < minEven)
        {
            minEven = tmp;
            posMinEven = j;
        }
        
        if(tmp > maxEven)
        {
            maxEven = tmp;
            posMaxEven = j;
        }
    }
 
    for(int i = 0; i < rows; ++i)
    {
        int m = arr[i][i];
        int p = arr[i][cols - i - 1];
        arr[i][posMaxEven] = m;
        arr[i][posMinEven] = p;
    }
    
    for(int i = 0; i < rows; ++i)
    {
        for(int j = 0; j < cols; ++j)
            std::cout << std::setw(6) << arr[i][j];
        std::cout << std::endl;
        delete[] arr[i];
    }
    delete[] arr;
    
    return 0;
}
Добавлено через 11 минут
Цитата Сообщение от Demortuus Посмотреть сообщение
Дан вещественный массив А[N][М], все элементы которого различны. В каждой строке найти элемент с наименьшим значением, а затем среди найденных элементов выбрать наибольший. Вывести на экран индексы этого элемента.
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
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <iomanip>
 
int main()
{
    srand(time(NULL));
    const int rows = 5;
    const int cols = 5;
    
    float **arr = new float* [rows];
    for(int i = 0; i < rows; ++i)
    {
        arr[i] = new float [cols + 1];
        arr[i][cols] = 0;
        for(int j = 0; j < cols; ++j)
        {
            arr[i][j] = rand() % 21;
            std::cout << std::setw(6) << arr[i][j];
            if(arr[i][j] < arr[i][static_cast<int>(arr[i][cols])])
                arr[i][cols] = j;
        }
        std::cout << std::endl;
    }
    std::cout << std::endl;
    
    int iMax = 0;
    for(int i = 1; i < rows; ++i)
    {
        if(arr[i][static_cast<int>(arr[i][cols])] > arr[iMax][static_cast<int>(arr[iMax][cols])])
            iMax = i;
    }
    
    std::cout << iMax << ' ' << arr[iMax][cols] << std::endl;
    
    for(int i = 0; i < rows; ++i)
        delete[] arr[i];
    delete[] arr;
    
    return 0;
}
Demortuus
1 / 1 / 0
Регистрация: 25.10.2010
Сообщений: 11
31.12.2011, 07:52  [ТС]     Помогите с задачками на C++ #5
Цитата Сообщение от soon Посмотреть сообщение
Может все-таки целый?
вот именно что четные... :\ да черт с ними... спасибо большое...
soon
 Аватар для soon
2536 / 1301 / 81
Регистрация: 09.05.2011
Сообщений: 3,086
Записей в блоге: 1
31.12.2011, 07:58     Помогите с задачками на C++ #6
Цитата Сообщение от Demortuus Посмотреть сообщение
вот именно что четные
Да это понятно, что четные. У вещественных чисел нет разделения на четные - нечетные. Поэтому я сделал массив с целыми числами, а не с вещественными.
Yandex
Объявления
31.12.2011, 07:58     Помогите с задачками на C++
Ответ Создать тему
Опции темы

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