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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.75
Depressa
3 / 3 / 0
Регистрация: 26.11.2011
Сообщений: 83
#1

Как вывести скалярное произведение двух массивов? - C++

31.12.2011, 14:13. Просмотров 1894. Ответов 9
Метки нет (Все метки)

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
#include <iostream>
#include <stdlib.h>
using namespace std;
void mas_in(int* a, int size)
{
    for(int i = 0; i < size; ++i)
        cin >> a[i];
}
void mas_out(int* a, int size)
{
    for(int i = 0; i < size; ++i)
        cout << a[i];
        cout <<endl;
}
void sub(int* a1,int* a2,int* result, int size)
{
     for(int i = 0; i < size; ++i)
         result[i]=a1[i] * a2[i];
}
int main(int argc, char *argv[])
{
    const int size = 4;
    int mas1[size], mas2[size], result[size];
    mas_in(mas1,size);
    mas_in(mas2,size);
    sub (mas1,mas2,result,size);
    mas_out(mas1,size);//
    mas_out(mas2,size);// 
    mas_out(result,size);
    return 0;
}
вот код, но это просто произведение, что добавить, чтобы было скалярное
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.12.2011, 14:13
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Как вывести скалярное произведение двух массивов? (C++):

Скалярное произведение двух массивов - C++
не могли бы подсказать, что в коде программы надо дописать, вышло только просто произведение #include &lt;iostream&gt; #include &lt;stdlib.h&gt; ...

Скалярное произведение двух массивов - C++
Напишите функцию, которая вычисляет скалярное произведение двух массивов.Массивы содержат элементы типа float. Каждый массив передается в...

ОпенМП расспаралелить скалярное произведение двух n-мерных векторов (массивов) - C++
Существует следующий код int main() { setlocale(LC_ALL, &quot;Russian&quot;); size_t n; cout &lt;&lt; &quot;Введите размерность...

Скалярное произведение двух векторов - C++
Даны два вектора (одномерных массива), содержащих n вещественных элементов. Найти скалярное произведение двух векторов.

Вычислить скалярное произведение двух векторов - C++
7.6.1. Помогите, пожалуйста, решить задачу в С++. Вычислить скалярное произведение двух векторов.

Выбрать пару векторов или массивов, которая даст минимальное скалярное произведение - C++
Добрый день, подскажите пожалуйста как создать n векторов или массивов, если изначально не известно сколько их будет? Вот условие...

9
oniks
1 / 1 / 0
Регистрация: 20.03.2011
Сообщений: 16
31.12.2011, 15:04 #2
Цитата Сообщение от Depressa Посмотреть сообщение
вот код, но это просто произведение, что добавить, чтобы было скалярное
Скалярное произведение предполагает наличие угла =)
1
Depressa
3 / 3 / 0
Регистрация: 26.11.2011
Сообщений: 83
31.12.2011, 15:09  [ТС] #3
Цитата Сообщение от oniks Посмотреть сообщение
Скалярное произведение предполагает наличие угла =)
отнюдь, в массиве, это произведение,а в конце суммированное
вроде этого а1[i]*b1[1]+а1[2]*b1[2]+а1[3]*b1[3]
где а1 b1- массивы
1,2,3 и тд- номера элементов
но вот как это записать саму сумму я не знаю
0
Ma3a
Эксперт С++
618 / 462 / 31
Регистрация: 28.01.2011
Сообщений: 605
31.12.2011, 15:19 #4
Depressa, скалярное произведение на то и скалярное, чтобы в результате его получалось число, то бишь скаляр, а не вектор, как имеет место у Вас.

C++
1
2
3
4
5
6
7
int inner_product(int * a1, int * a2, int size)
    {
    int result = 0;
    for(int idx = 0; idx < size; ++idx)
        result += a1[idx] * a2[idx];
    return result;
    }
1
alex_x_x
бжни
2449 / 1654 / 84
Регистрация: 14.05.2009
Сообщений: 7,162
31.12.2011, 15:25 #5
C++
1
2
3
4
5
6
7
8
9
10
11
12
#include <algorithm>
#include <iostream>
#include <functional>
 
int main()
{
   int a[] = { 1, 2, -3 },
       b[] = { 2, 3,  4 };
 
   std::cout << std::inner_product (a, a + sizeof(a)/sizeof(a[0]), 
                                    b, 0, std::plus<int>(),std::multiplies<int>());
}
1
Mr.X
Эксперт С++
3050 / 1695 / 265
Регистрация: 03.05.2010
Сообщений: 3,867
31.12.2011, 15:41 #6
alex_x_x, все правильно, только этот алгоритм содержится в файле numeric, а пятый и шестой аргументы можно опустить, так как они там по умолчанию.
0
alex_x_x
бжни
2449 / 1654 / 84
Регистрация: 14.05.2009
Сообщений: 7,162
31.12.2011, 15:45 #7
Цитата Сообщение от Mr.X Посмотреть сообщение
а пятый и шестой аргументы можно опустить, так как они там по умолчанию
ааа, может быть, ну все-равно так наглядней
0
Depressa
3 / 3 / 0
Регистрация: 26.11.2011
Сообщений: 83
31.12.2011, 15:46  [ТС] #8
сделал как написал Ma3a
при вводе чисел ( 1,2,3,4) на оба массива
выдает белиберду
0124497241991174219176
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
#include <iostream>
#include <stdlib.h>
using namespace std;
void mas_in(int* a, int size)
{
    for(int i = 0; i < size; ++i)
        cin >> a[i];
}
void mas_out(int* a, int size)
{
    for(int i = 0; i < size; ++i)
        cout << a[i];
    cout <<endl;
}
void sub(int* a1,int* a2,int* result, int size)
{
    result=0;
    for(int idx = 0; idx < size; ++idx)
        result +=a1[idx] * a2[idx];
 
}
int main(int argc, char *argv[])
{
    const int size = 4;
    int mas1[size], mas2[size], result[size];
    mas_in(mas1,size);
    mas_in(mas2,size);
    sub (mas1,mas2,result,size);
    mas_out(mas1,size);
    mas_out(mas2,size);
    mas_out(result,size);
    return 0;
}
0
Ma3a
Эксперт С++
618 / 462 / 31
Регистрация: 28.01.2011
Сообщений: 605
31.12.2011, 15:52 #9
Depressa, ещё раз, скалярное произведение двух векторов — это число. Сделали вы совсем не так, как я сказал, ибо в вашей функции sub творится что-то совершенно непонятное. Массив result, который зачем-то передаётся в функцию sub, никак не инициализируется, поэтому из него выводится мусор.

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
#include <iostream>
#include <stdlib.h>
using namespace std;
void mas_in(int* a, int size)
{
    for(int i = 0; i < size; ++i)
        cin >> a[i];
}
void mas_out(int* a, int size)
{
    for(int i = 0; i < size; ++i)
        cout << a[i];
    cout <<endl;
}
int sub(int* a1, int* a2, int size)
{
    int result=0;
    for(int idx = 0; idx < size; ++idx)
        result +=a1[idx] * a2[idx];
    return result;
}
int main(int argc, char *argv[])
{
    const int size = 4;
    int mas1[size], mas2[size], result[size];
    mas_in(mas1,size);
    mas_in(mas2,size);
    int product = sub (mas1,mas2,size);
    
    cout << product << endl;
    return 0;
}
1
Depressa
3 / 3 / 0
Регистрация: 26.11.2011
Сообщений: 83
31.12.2011, 16:04  [ТС] #10
Благодарю
0
31.12.2011, 16:04
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
31.12.2011, 16:04
Привет! Вот еще темы с ответами:

Найти скалярное произведение двух n-мерных векторов - C++
У меня вообще не понимаю. И ничего не получился! Задача СИ : Написать программу, которая находит скалярное произведение двух n-мерных...

Найдите сумму, разность и скалярное произведение двух векторов - C++
помогите пожалуйста с задачей Найдите сумму, разность и скалярное произведение двух векторов в N-мерном пространстве.

Найти произведение двух двумерных массивов - C++
Помогите, пожалуйста, разобраться. Код компилируется, но выдает совсем не то, что нужно. Задание: создать два двухмерных массива А 5*3...

Поэлементное произведение элементов двух массивов - C++
Написать программу, в которой объявляется три массива одинакового размера. Первые два массива заполняются случайными числами в диапазоне от...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru