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

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

01.06.2010, 12:08. Показов 3945. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru