Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.74/19: Рейтинг темы: голосов - 19, средняя оценка - 4.74
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71

В одномерном массиве, состоящем из n вещественных элементов, вычислить:

01.06.2010, 12:08. Показов 4038. Ответов 24
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
1)количество положительных элементов массива;
2)сумму элементов массива, расположенных после последнего элемента равного нулю.
3)Преобразовать массив таким образом, чтобы сначала располагались все элементы, целая часть которых не превышает 1, а потом – все остальные.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.06.2010, 12:08
Ответы с готовыми решениями:

В одномерном массиве, состоящем из n вещественных элементов, вычислить
Ребята помогите плиз с задачей,заранее спасибо большое В одномерном массиве, состоящем из 30 вещественных элементов, вычислить: 1)...

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

В одномерном массиве, состоящем из n вещественных элементов, вычислить
В одномерном массиве, состоящем из n вещественных элементов, вычислить: 1.количество элементов массива, равных 0; 2.сумму и количество ...

24
1552 / 918 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
01.06.2010, 12:14
В чем у вас трудности?
0
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71
01.06.2010, 12:31  [ТС]
необходимо решить задачу
1
302 / 160 / 62
Регистрация: 27.02.2010
Сообщений: 317
01.06.2010, 13:36
Цитата Сообщение от winelove Посмотреть сообщение
необходимо решить задачу
Видимо, одна большая трудность ...
Пункт 3) непонятен - нужно сортировать, или последовательность элементов не должна
меняться? Не превышает 1... включая 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
#include <iostream>
 
using namespace std;
const int SIZE=80;
int main()
{
    setlocale (LC_ALL, "Russian"); //чтобы на русском можно было писать...
    int n, i, j=0, k=0; //объявление переменных
    double a[SIZE], sum=0;
    cout<<"Введите количество элементов: ";
    cin>>n;
    cout<<"Введите "<<n<<" элементов: "; 
    for (i=0; i<n; i++) //ввод элементов массива
        cin>>a[i];
    for (i=0; i<n; i++) //подсчет положительных
        if (a[i]>=0)
            k++;
    cout<<"В массиве "<<k<<" положительных элементов.\n";
    for (i=n-1; i>=0; i--) //поиск индекса последнего нулевого элемента
        if (a[i]==0)
        {
            j=i;
            break;
        }
    for (i=j+1; i<n; i++)//подсчет суммы после последнего 0
        sum+=a[i];
    cout<<"Сумма = "<<sum<<endl;
 
    cout<<endl<<endl;
    return 0;
}
0
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71
01.06.2010, 13:50  [ТС]
нужно сортировать я так думаю
включая единицу

Добавлено через 1 минуту
хотя сортируй-не сортируй, мне кажется ниче не изменится, они так и будут в той последовательности, в какой надо
0
302 / 160 / 62
Регистрация: 27.02.2010
Сообщений: 317
01.06.2010, 13:58
Вам неправильно кажется. Изменится.
Если уж вам лень написать пример, напишу я:
исходная последовательность:
1,5 3,9 4,8 2,1 1,2 0,5 7,4 5,6
Если отсортировать, бедет так:
0,5 1,2 1,5 2,1 3,9 4,8 5,6 7,4 (порядок цифр изменился!)
просто в начало поставить нужные элементы (сохраняя последовательность!):
1,5 1,2 0,5 3,9 4,8 2,1 7,4 5,6
0
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
01.06.2010, 14:03
и снова алгоритмы %)

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
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
#include <numeric>
 
template <typename T> T rnd() { 
   return T(rand())/rand();
}
 
template <typename T> bool is_pos(const T &a) { 
   return a > 0; 
}
 
int main()
{
   // генерация массива
   std::vector<float> v(6);
   std::generate_n(v.begin(), v.size(), rnd<float>);
   v[3] = 0; // обязательный ноль :)
   // вывод массива
   std::copy(v.cbegin(), v.cend(), std::ostream_iterator<float>(std::cout, "\n"));
   std::cout << "---" << std::endl;
   // количество положительных элементов
   std::cout << std::count_if(v.cbegin(), v.cend(), is_pos<float>) << std::endl;
   // сумма после последнего нуля
   std::cout << std::accumulate(std::find(v.rbegin(), v.rend(), 0).base(), v.end(), 0) << std::endl;
   // сортировка массива
   std::sort(v.begin(), v.end());
   // вывод массива
   std::cout << "---" << std::endl;
   std::copy(v.cbegin(), v.cend(), std::ostream_iterator<float>(std::cout, "\n"));
 
   system("pause");
   return 0;
}
1
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71
01.06.2010, 14:07  [ТС]
Мне не лень, просто я не подумала об этом
Если отсортировать, бедет так:
0,5 1,2 1,5 2,1 3,9 4,8 5,6 7,4
вот так я думаю надо
0
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
01.06.2010, 14:08
Цитата Сообщение от NNN777 Посмотреть сообщение
C++
1
2
3
4
5
6
for (i=n-1; i>=0; i--) //поиск индекса последнего нулевого элемента
   if (a[i]==0)
   {
      j=i;
      break;
   }
а почему бы не написать вот так:
C++
1
2
for(i = n - 1; i >= 0 && a[i] != 0; --i) ;
j = i
и кстати что будет, если нуля в последовательности не окажется?
1
302 / 160 / 62
Регистрация: 27.02.2010
Сообщений: 317
01.06.2010, 14:13
Да, по поводу 0 неопределено)... fasked, спасибо)
А по поводу более краткой записи, просто хотелось, чтобы человек понял ) а там и не знаю, что проще понять)))
winelove, подумайте еще об отрицательных числах, если просто отсортировать массив -4,5 будет где-то в начале, что не допустимо. Еще раз прошу вас привести пример.
0
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
01.06.2010, 14:20
Цитата Сообщение от fasked Посмотреть сообщение
и кстати что будет, если нуля в последовательности не окажется?
а у самого то тоже не работает xD
вот так будет более работоспособно:
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
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
#include <numeric>
 
template <typename T> T rnd() { 
   return T(rand() / rand());
}
 
template <typename T> bool is_pos(const T &a) { 
   return a > 0; 
}
 
int main()
{
   // генерация массива
   std::vector<float> v(6);
   std::generate_n(v.begin(), v.size(), rnd<float>);
   //v[3] = 0; // обязательный ноль :)
   // вывод массива
   std::copy(v.cbegin(), v.cend(), std::ostream_iterator<float>(std::cout, "\n"));
   std::cout << "---" << std::endl;
   // количество положительных элементов
   std::cout << std::count_if(v.cbegin(), v.cend(), is_pos<float>) << std::endl;
   // сумма после последнего нуля
   if(std::find(v.rbegin(), v.rend(), 0) != v.rend())
      std::cout << std::accumulate(std::find(v.rbegin(), v.rend(), 0).base(), v.end(), 0) << std::endl;
   else
      std::cout << "0 not found" << std::endl;
   // сортировка массива
   std::sort(v.begin(), v.end());
   // вывод массива
   std::cout << "---" << std::endl;
   std::copy(v.cbegin(), v.cend(), std::ostream_iterator<float>(std::cout, "\n"));
 
   system("pause");
   return 0;
}
0
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71
01.06.2010, 14:38  [ТС]
например дана последовательность:
0,1 5,6 0,5 6,4 5,8 0,2 -0,9 0,3
должно получится:
-0,9 0,1 0,2 0,3 0,5 5,6 5,8 6,4

если так сделать не получается, то пусть будет хотя бы не по порядку, а просто сначала числа, целая часть которых не превышает 1, потом все остальные
0
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
01.06.2010, 15:19
Цитата Сообщение от winelove Посмотреть сообщение
например дана последовательность:
0,1 5,6 0,5 6,4 5,8 0,2 -0,9 0,3
должно получится:
-0,9 0,1 0,2 0,3 0,5 5,6 5,8 6,4
если так сделать не получается, то пусть будет хотя бы не по порядку, а просто сначала числа, целая часть которых не превышает 1, потом все остальные
кажется вы не поняли сути. сейчас вы привели пример обычной сортировки. а вопрос в другом, что делать с отрицательными числами целая часть, которых больше единицы. такие числа как -1.015, -2, -3.
при обычной сортировке они попадут в начало массива. в общем стоит выбрать один из двух вариантов: брать число по модулю или просто.
0
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71
01.06.2010, 15:22  [ТС]
аа блин, я это опять не учла
ну наверно лучше просто сделать(2 вариант)
0
302 / 160 / 62
Регистрация: 27.02.2010
Сообщений: 317
01.06.2010, 16:26
Не самый рациональный вариант, но все же
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
#include <iostream>
#include <math.h>
 
using namespace std;
const int SIZE=80;
int main()
{
        setlocale (LC_ALL, "Russian"); //чтобы на русском можно было писать...
        int n, i, j=-1, k=0, z, d=0; //объявление переменных
        double a[SIZE], sum=0, buf=0;
        cout<<"Введите количество элементов: ";
        cin>>n;
        cout<<"Введите "<<n<<" элементов: "; 
        for (i=0; i<n; i++) //ввод элементов массива
                cin>>a[i];
        for (i=0; i<n; i++) //подсчет положительных
                if (a[i]>=0)
                        k++;
        cout<<"В массиве "<<k<<" положительных элементов.\n";
       for(i = n - 1; i >= 0 && a[i] != 0; --i);
       j = i;
       if (j==-1)
            cout<<"Отрицательных чисел нет. Сумма = 0.\n";
       else
       {
           for (i=j+1; i<n; i++)//подсчет суммы после последнего 0
                sum+=a[i];
            cout<<"Сумма = "<<sum<<endl;
       }
       for (i=0; i<n; i++)
           if (a[i]>-2&&a[i]<2)
           {
               buf=a[i];
               for (j=i; j<n; j++)
                   a[j]=a[j+1];
                for (j=n; j>d; j--)
                    a[j]=a[j-1];
                a[d]=buf;
                d++;
           }
        for (i=0; i<n; i++)
           cout<<a[i]<<" ";
        cout<<endl<<endl;
        return 0;
}
0
Эксперт С++
 Аватар для fasked
5045 / 2624 / 241
Регистрация: 07.10.2009
Сообщений: 4,310
Записей в блоге: 5
01.06.2010, 16:39
что-то перемудрил... отсортировать таким образом можно, как я уже говорил, если брать модуль числа
C
1
2
3
   for(i = 1; i < n; ++i)
      if(fabs(a[i]) < fabs(a[i-1]))
         ; /*swap*/
Code
1
1, 0.15, -2, 7 ---> 0.15, 1, -2, 7
1
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71
01.06.2010, 16:39  [ТС]
после того как я ввожу элементы окно закрывается
это что значит?
0
302 / 160 / 62
Регистрация: 27.02.2010
Сообщений: 317
01.06.2010, 16:45
winelove, добавьте
C++
1
system ("pause");
до return 0;
fasked, я вообще не сортирую массив) - я запоминаю число (если оно больше -2 и меньше 2) ,удаляю его из массива и записываю в позицию d, которая увеличивается при каждой такой записе)... Говорю, не самыый рациональный вариант, но зато вроде понятный
1
1552 / 918 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
01.06.2010, 16:46
faksed,, объясни пару строк:
22:
C++
1
 std::copy(v.cbegin(), v.cend(), std::ostream_iterator<float>(std::cout, "\n"));
cbegin, cend?

27-28:
C++
1
2
if(std::find(v.rbegin(), v.rend(), 0) != v.rend())
      std::cout << std::accumulate(std::find(v.rbegin(), v.rend(), 0).base(), v.end(), 0) << std::endl;
Общий смысл понятен, но: rbegin, rend(почему не воспользоваться begin,end?), base(), тоже беспонятия =)
Спс.
0
 Аватар для winelove
2 / 2 / 0
Регистрация: 10.05.2010
Сообщений: 71
01.06.2010, 16:53  [ТС]
ошибка: Call to undefined function 'system'
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.06.2010, 16:53
Помогаю со студенческими работами здесь

в одномерном массиве, состоящем из n вещественных элементов, вычислить:
В одномерном массиве, состоящем из n вещественных элементов, вычислить: 1) сумму и количество элементов массива, расположенных между...

В одномерном массиве, состоящем из N вещественных элементов, вычислить:
В одномерном массиве, состоящем из n вещественных элементов, вычислить: а) минимальный элемент массива; б) сумму элементов массива,...

В одномерном массиве В, состоящем из N вещественных элементов, вычислить:
количество элементов, удовлетворяющих условию 5&lt;Bi&lt;7.

В одномерном массиве состоящем из n вещественных элементов вычислить:
Сумму элементов массива, расположенных после минимального элемента Добавлено через 3 минуты Помогите пожалуйста с задачками:umbrage:...

В одномерном массиве, состоящем из n вещественных элементов вычислить
Всем привет помогите пожалуйста решить эти 3 задачи на С++ пожалуйста училка по программированию ничерта нормально не объясняет а требует...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru