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

вычисление наименьшей суммы элементов - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Найти женщин-владельцев заданной марки автомобиля http://www.cyberforum.ru/cpp-beginners/thread446403.html
Используя записи с полями: авто - с полями марка, регистрационный номер, пробег; анкета - с полями фамилия, пол, авто в массиве из 15 элементов типа анкета найти женщин-владельцев заданной марки...
C++ Как вернуть обьект тип которого заранее неизвестно решил поучить паттерны, застрял малость на одном, а точнее на его реализации, паттер называеться Вариант, смысл его, убрать типизацию... #include <iostream> #include <memory> class Variant { ... http://www.cyberforum.ru/cpp-beginners/thread446394.html
Передать массив структур в функцию C++
#include <iostream> #include <cstring> using namespace std; typedef struct { char fname; char lname; } fl; void see(fl * ptr, int i)
C++ Нарушение прав доступа при записи. Висящий указатель нашел, но не знаю как исправить ситуацию
Здравствуйте! Имеется программа поиска коллизий в хэш-функции #include <stdio.h> #include <stdlib.h> #define n 30 //размер таблицы unsigned int ELFHash(char* str, unsigned int len) //...
C++ Найти порядковые номера позиций http://www.cyberforum.ru/cpp-beginners/thread446374.html
Дана строка. Найти порядковые номера позиций всех запятых в этой строке. Если строка не содержит запятых либо содержит только одну запятую, выдать сообщения об этом. Совсем ничего не соображаю:cry:
C++ Написать программу па методу Гаусса Кто может написать программу па методе Гаусса подробнее

Показать сообщение отдельно
Roof
154 / 154 / 10
Регистрация: 03.11.2010
Сообщений: 393
15.02.2012, 22:17
Мой вариант решения данной задачи.
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
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <time.h>
 
#define ROWS 6
#define COLS 7
 
// тип данных для хранения номера строки матрицы и суммы элементов строки
struct data_t {
    size_t number_row;
    double min_sum;
};
 
// заполнение массива случайными целочисленными значениями
void fill_array( double[ ], const size_t, const size_t );
// вывод массива на экран
void print_array( const double[ ], const size_t, const size_t );
// подсчет суммы элементов каждой строки матрицы и нахождение среди этих сумм наименьшей суммы
struct data_t min_sum_row( const double[ ], const size_t, const size_t );
 
int main( void ) {
    srand( time( NULL ) );
    double my_arr[ ROWS ][ COLS ];
 
    fill_array( *my_arr, ROWS, COLS );
 
    puts( "Исходная матрица:" );
    print_array( *my_arr, ROWS, COLS );
    puts( "" );
 
    struct data_t my_data = min_sum_row( *my_arr, ROWS, COLS );
    printf( "Номер строки с наименьшей суммой элементов %u\n",
            my_data.number_row );
    printf( "Сумма элементов данной строки %4.2lf\n", my_data.min_sum );
 
    return EXIT_SUCCESS;
}
 
void fill_array( double array[ ], const size_t dimm1, const size_t dimm2 ) {
    size_t i, j;
    for ( i = 0; i < dimm1; ++i )
        for ( j = 0; j < dimm2; ++j )
            array[ i * dimm2 + j ] = rand() % 100; // [0..99];
}
 
void print_array( const double array[ ], const size_t dimm1,
        const size_t dimm2 ) {
    size_t i, j;
    for ( i = 0; i < dimm1; ++i ) {
        for ( j = 0; j < dimm2; ++j )
            printf( "%4.2lf  ", array[ i * dimm2 + j ] );
 
        puts( "" );
    }
}
 
struct data_t min_sum_row( const double array[ ], const size_t dimm1,
        const size_t dimm2 ) {
 
    size_t i, j;
    double arr_sum[ dimm1 ];
 
    for ( i = 0; i < dimm1; ++i ) {
        arr_sum[ i ] = 0;
        for ( j = 0; j < dimm2; ++j )
            arr_sum[ i ] += array[ i * dimm2 + j ];
    }
 
    struct data_t curr_data = { .number_row = 0, .min_sum = arr_sum[ 0 ] };
    for ( i = 1; i < dimm1; ++i )
        if ( arr_sum[ i ] < curr_data.min_sum ) {
            curr_data.min_sum = arr_sum[ i ];
            curr_data.number_row = i;
        }
 
    return curr_data;
}
1
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru