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

Модуль в массиве - C++

Восстановить пароль Регистрация
 
~Sл@\/яH~
0 / 0 / 0
Регистрация: 17.12.2011
Сообщений: 13
18.12.2011, 21:10     Модуль в массиве #1
Добрый вечер. Подскажите мне пожалуйста вот с этой задачей:


В одномерном массиве, состоящем из n вещественных элементов, вычислить:
• номер минимального элемента;
• сумму элементов массива, расположенных между первым и вторым отрицательными элементами.
• Преобразовать таким образом, чтобы сначала располагались все элементы, модуль которых не превышает 1, а потом – все остальные.

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
#include <iostream>
#include <conio.h>
#include <math.h>
#include <windows.h>
using namespace std;
const int n=10;            
int main()
{
  SetConsoleCP (1251);
  SetConsoleOutputCP (1251);
 
  int X[n],imin,s;        
  int i,j,k1,k2;
  cout<<"Введите элементы массива: ";
  for (i=0;i<n;i++)
    cin >> X[i];           
  imin=0;                 
  for (i=0;i<n;i++)
      if (X[i]<X[imin])
        imin = i;
  cout<<"Номер минимального элемента массива: "<<imin<<'\n'; 
 
  k1 = 0;
  k2 = 0;
  for (i=0;i<n;i++)
    if (X[i]<0)
      if (k1!=0)
{
    k2 = i;
    break;
} 
      else
    k1 = i;              
 
  s = 0;                  
  for (i=k1+1;i<k2;i++)
    s = s + X[i];          
  cout<<"Сумма элементов между первым и вторым отрицательным элементам= "<<s<<'\n'; 
 
  float mas2[n];
  for (i=0;i<n;i++)
    mas2[i] = X[i];        
  int k = -1;              
  for (i=0;i<n;i++)
    if (abs(mas2[i]) <= 1)
{    
      k++;                 
      X[k] = mas2[i];      
}
  for (i=0;i<n;i++)
    if (abs(mas2[i]) >= 1)
{
      k++;
      X[k] = mas2[i];      
}
  cout<<"Преобразованный массив: "<<'\n';
  for (i=0;i<n;i++)
    cout<<X[i]<<' ';
  getch ();
  return 0;
}
Все работает, но вот в 3 с модулями выдает много единиц.
Миниатюры
Модуль в массиве  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.12.2011, 21:10     Модуль в массиве
Посмотрите здесь:

C++ Не могу найти ошибку с подсчетом суммы элементов в интервале[a,b] в динамическом одномерном массиве массиве.
Массив: В массиве a[1 … 67] заменить нулями члены, модуль которых при делении на p дает в остатке q. C++
C++ Найти в массиве максимальный и минимальный элементы в массиве и их количество
C++ Из массива А удалить те элементы, встречающиеся и в массиве А и в массиве В хотя бы два раза
C++ Определить модуль какого из двух чисел встречается в числовом массиве чаще
Вывести элементы, которые есть в массиве А в нескольких экземплярах и отсутствуют в массиве В C++
C++ В двухмерном массиве найти максимальный и минимальный элементы и их координаты в массиве
Проверить, есть ли в массиве А [n] числа В и С и определить, какое из чисел встречается в массиве чаще C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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