С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
felicita_091
8 / 8 / 1
Регистрация: 24.10.2012
Сообщений: 428
#1

Найти сумму модулей массива - C++

12.12.2012, 13:23. Просмотров 331. Ответов 3
Метки нет (Все метки)

Работа с линейным и динамическим массивом.
В одномерном массиве, состоящем из n вещественных элементов (размерность массива задается пользователем), найдите сумму модулей массива. При разработке кода для перебора элементов массива использовать не индекс массива, а указатель на элемент массива. , сствснных элементов (размерность массива задаётсяпользователем), найдите с\мм . м ; 'CVCHTOB массива. При разработке кода для перебора элементов массива.
Вычисления должны выполняться в отдельной функции.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.12.2012, 13:23
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Найти сумму модулей массива (C++):

Найти сумму модулей массива до первого нуля - C++
1) в одномерном массиве (а не в матрице) найти сумму модулей до первого нуля. Если нуль в начале массива, получить нуль, а если нет - сумму...

Массивы. Найти минимальный по модулю элемент массива. Найти сумму модулей элементов после первого нуля - C++
народ,траблы,никак не могу понять массивы,подскажите пожалуйста /*1. Найти минимальный по модулю элемент массива. 2. Найти сумму...

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

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

Найти сумму модулей отрицательных нечетных элементов двумерного массива - C++
Дан двухмерный массив 7×7. Найти сумму модулей отрицательных нечетных элементов

Найти сумму модулей элементов массива, расположенных после первого положительного - C++
типичная задачка: В одномерном массиве, состоящем из n вещественных элементов, вычислить: 1. номер максимального по модулю элемента...

3
taras atavin
3570 / 1754 / 91
Регистрация: 24.11.2009
Сообщений: 27,567
12.12.2012, 13:50 #2
Цитата Сообщение от felicita_091 Посмотреть сообщение
адание 2: Работа с линейным и динамическим массивом.
В одномерном массиве, состоящем из n вещественных элементов (размерность массива задается пользователем), найдите сумму модулей массива. При разработке кода для перебора элементов массива использовать не индекс массива, а указатель на элемент массива. , сствснных элементов (размерность массива задаётсяпользователем), найдите с\мм . м ; 'CVCHTOB массива. При разработке кода для перебора элементов массива.
Вычисления должны выполняться в отдельной функции.
Почему и? По смыслу это один массив.

Добавлено через 16 минут
Цитата Сообщение от felicita_091 Посмотреть сообщение
В одномерном массиве, состоящем из n вещественных элементов (размерность массива задается пользователем), найдите сумму модулей массива. При разработке кода для перебора элементов массива использовать не индекс массива, а указатель на элемент массива. , сствснных элементов (размерность массива задаётсяпользователем), найдите с\мм . м ; 'CVCHTOB массива. При разработке кода для перебора элементов массива.
Вычисления должны выполняться в отдельной функции.
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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
#include <iostream>
template <class TItem> class TArray
{
 protected:
  TItem             *Data;
  size_t             Count;
 public   :
                     TArray          (                          );
                     TArray          (TArray           &Original);
                    ~TArray          (                          );
  TArray             operator =      (TArray           &Original);
  TItem             &operator []     (size_t            Index   );
                     operator bool   (                          );
                     operator size_t (                          );
  bool               ReSize          (size_t            Count   );
};
template
<class TItem>
TArray <TItem> ::    TArray          (                          )
{
 Data =NULL;
 Count=0;
}
template
<class TItem>
TArray <TItem> ::    TArray          (TArray           &Original)
{
 TItem *Source;
 TItem *Target;
 if (Original.Count>0)
 {
  Data=new TItem [Original.Count];
  if (Data)
  {
   for (Source=Original.Data+Original.Count-1, Target=Data+Original.Count-1; Target>=Data; --Source, --Target)
   {
    *Target=*Source;
   }
   Count=Original.Count;
  }
  else
  {
   Count=0;
  }
 }
 else
 {
  Data =NULL;
  Count=0;
 }
}
template
<class TItem>
TArray <TItem> ::   ~TArray          (                          )
{
 if (Data)
 {
  delete [] Data;
 }
 Data =NULL;
 Count=0;
}
template
<class TItem>
TArray <TItem>
TArray <TItem> ::    operator =      (TArray           &Original)
{
 TItem *Source;
 TItem *Target;
 if (Original.Count>0)
 {
  Data=new TItem [Original.Count];
  if (Data)
  {
   for (Source=Original.Data+Original.Count-1, Target=Data+Original.Count-1; Target>=Data; --Source, --Target)
   {
    *Target=*Source;
   }
   Count=Original.Count;
  }
  else
  {
   Count=0;
  }
 }
 else
 {
  Data =NULL;
  Count=0;
 }
 return *this;
}
template
<class TItem>
TItem               &
TArray <TItem> ::    operator []     (size_t            Index   )
{
 return Data[Index];
}
 
template
<class TItem>
TArray <TItem> ::    operator bool   (                          )
{
 return (Count>0);
}
template
<class TItem>
TArray <TItem> ::    operator size_t (                          )
{
 return Count;
}
bool                 
template
<class TItem>
TArray <TItem> ::    ReSize          (size_t            Count   )
{
 size_t  Size;
 TItem  *Buffer;
 TItem  *Source;
 TItem  *Target;
 size_t  ForCopy;
 if (Count==0)
 {
  if (Data)
  {
   delete [] Data;
  }
  Data=NULL;
  this->Count=0;
  return true;
 }
 Size=Count*sizof(TItem);
 if (Count!=Size/sizof(TItem))
 {
  return false;
 } 
 Buffer=new TItem [Count];
 if (Buffer)
 {
  if (Count>this->Count)
  {
   ForCopy=Count;
  }
  else
  {
   ForCopy=this->Count;
  }
  for (Source=Data+ForCopy-1, Target=Buffer+ForCopy-1; Target>=Buffer; --Source, --Target)
  {
   *Target=*Source;
  }
  if (Data)
  {
   delete [] Data;
  }
  Data=NULL;
  this->Count=0;
  return true;
 }
 return false;
}
double abs(double x)
{
 if (x<0.0)
 {
  return -x;
 }
 return x;
}
int main ()
{
 TArray <double> Array;
 double *p;
 double sum;
 size_t n;
 std::cout<<"Введи раззмер"<<std::endl;
 std::cin>>n;
 Array.ReSize(n);
 for (p=Array[n-1]; p>=Array[0]; --p)
 {
  std::cin>>*p;
 }
 for (p=Array[n-1], sum=0.0; p>=Array[0]; --p)
 {
  sum+=abs(*p);
 }
 std::cout<<"Сумма модулей "<<sum<<std::endl;
 return 0;
}
0
rangerx
1937 / 1546 / 141
Регистрация: 31.05.2009
Сообщений: 2,913
12.12.2012, 15:47 #3
Цитата Сообщение от felicita_091 Посмотреть сообщение
Задание 2: Работа с линейным и динамическим массивом.
В одномерном массиве, состоящем из 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
#include <iostream>
#include <cmath>
 
double sum_of_abs(const double* a, size_t n) {
 
    double sum = 0;
    
    for(const double* p = a; p != a + n; ++p)
        sum += std::fabs(*p);
 
    return sum;
}
 
int main() {
 
    size_t n;
    std::cout << "n = ";
    std::cin >> n;    
    
    double* a = new double [n];
    
    for(double* p = a; p != a + n; ++p) {
 
        std::cout << "-> ";
        std::cin >> *p;
    }
 
    std::cout << sum_of_abs(a, n) << std::endl;
 
    delete[] a;
}
0
taras atavin
3570 / 1754 / 91
Регистрация: 24.11.2009
Сообщений: 27,567
12.12.2012, 15:54 #4
Цитата Сообщение от taras atavin Посмотреть сообщение
C++
1
2
3
4
5
6
7
8
for (p=Array[n-1]; p>=Array[0]; --p)
{
 std::cin>>*p;
}
for (p=Array[n-1], sum=0.0; p>=Array[0]; --p)
{
 sum+=abs(*p);
}
Не множко ошибся.
C++
1
2
3
4
5
6
7
8
for (p=&Array[n-1]; p>=&Array[0]; --p)
{
 std::cin>>*p;
}
for (p=&Array[n-1], sum=0.0; p>=&Array[0]; --p)
{
 sum+=abs(*p);
}
0
12.12.2012, 15:54
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.12.2012, 15:54
Привет! Вот еще темы с ответами:

Найти сумму модулей элементов массива, расположенных после минимального по модулю элемента - C++
Дан целочисленный массив размера n. Нужно: Найти сумму модулей элементов массива, расположенных после минимального по модулю элемента.

Найти сумму модулей элементов массива, расположенных после первого отрицательного элемента - C++
В одномерном массиве, состоящем из n вещественных элементов, вычислить: 1) номер минимального по модулю элемента массива; 2) сумму...

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

Найти сумму модулей элементов массива, расположенных после первого отрицательного элемента - C++
Найти сумму модулей элементов массива, расположенных после первого отрицательного элемента. Вот код: #include &lt;conio.h&gt; #include...


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

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

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