0 / 0 / 0
Регистрация: 23.10.2011
Сообщений: 17
1

Задачка с массивом

25.10.2011, 11:33. Показов 1605. Ответов 20
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Как решить эту задачу в Си?
Дан массив вещественных случайных чисел (размер массива определяет поль-зователь, но в диапазоне [3;20]). Подсчитать сумму положительных чисел.
0
25.10.2011, 11:33
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.10.2011, 11:33
Ответы с готовыми решениями:

Задачка с массивом
Здравствуйте, обучаясь на первом курсе ивт столкнулся с проблемной задачей =\ с массивами совсем не получается найти общего языка =\...

Задачка с квадратным массивом
В квадратном массиве записаны целые числа. Определить: а) произведение элементов побочной диагонали, меньших 10 б) сумму элементов...

Задачка с массивом слов и символов
Всем доброго времени суток! В университете дали решить такую задачу: "Дан массив слов и подстрока. Для всех слов массива, если...

20
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
25.10.2011, 11:37 2
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include<stdlib.h>
#include<stdio.h>
#include<time.h>
#define A 3.0
#define B 20.0
 
int main()
{
   double *a;
   int i, n, size;
   srand(time(NULL));
   scanf("%d", &size);
   a = (double *)malloc(size*sizeof(*a));
   for (n = i = 0; i < size; i++)
   {
      a[i] = (rand()%(B-A+1) + A) / (B - A);
      printf("%.2f ", a[i]);
      if (a[i] > 0)
         n++;
   }
   printf("\n n = %d\n", n);
   return 0;
}
0
0 / 0 / 0
Регистрация: 23.10.2011
Сообщений: 17
25.10.2011, 11:41  [ТС] 3
Цитата Сообщение от Thinker Посмотреть сообщение
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include<stdlib.h>
#include<stdio.h>
#include<time.h>
#define N 100
#define A 3.0
#define B 20.0
 
int main()
{
   double a[N];
   int i;
   srand(time(NULL));
   for (i = 0; i < N; i++)
   {
      a[i] = (rand()%(B-A+1) + A) / (B - A);
      printf("%.2f ", a[i]);
   }
}
Это что? Это ничего не компилируется
0
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
25.10.2011, 11:45 4
Цитата Сообщение от Mashylya1 Посмотреть сообщение
Это что? Это ничего не компилируется
Не компилировал. Если есть ошибки, то сами, наверное, в состоянии исправить. Я там переделал кое-что.
0
В вечном поиске...
 Аватар для Nursik77
275 / 235 / 30
Регистрация: 05.04.2011
Сообщений: 645
25.10.2011, 11:47 5
Thinker, наверное имеется ввиду это: https://www.cyberforum.ru/cpp-... 10807.html
0
0 / 0 / 0
Регистрация: 23.10.2011
Сообщений: 17
25.10.2011, 11:47  [ТС] 6
Цитата Сообщение от Thinker Посмотреть сообщение
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include<stdlib.h>
#include<stdio.h>
#include<time.h>
#define A 3.0
#define B 20.0
 
int main()
{
   double *a;
   int i, n, size;
   srand(time(NULL));
   scanf("%d", &size);
   a = (double *)malloc(size*sizeof(*a));
   for (n = i = 0; i < size; i++)
   {
      a[i] = (rand()%(B-A+1) + A) / (B - A);
      printf("%.2f ", a[i]);
      if (a[i] > 0)
         n++;
   }
   printf("\n n = %d\n", n);
   return 0;
}
Выдает ошибку // a[i] = (rand()%(B-A+1) + A) / (B - A);???
0
93 / 69 / 22
Регистрация: 17.10.2011
Сообщений: 235
25.10.2011, 11:55 7
Цитата Сообщение от Thinker Посмотреть сообщение
C
1
2
3
...
      a[i] = (rand()%(B-A+1) + A) / (B - A);
...
у тебя генерируюстя только целые числа
в условии сказано про вещественные
предлагаю такой вариант
C++
1
a[i] = ((double)rand()/(RAND_MAX) * (B - A) + A;
1
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
25.10.2011, 11:57 8
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
#include<stdlib.h>
#include<stdio.h>
#include<time.h>
#include<conio.h>
#define A 3
#define B 20
 
int main()
{
   double *a;
   int i, n, size;
   srand(time(NULL));
   scanf("%d", &size);
   a = (double *)malloc(size*sizeof(*a));
   for (n = i = 0; i < size; i++)
   {
      a[i] = (1.0*(rand()%(B-A+1)) + A) / (1.0*(B - A));
      printf("%.2f ", a[i]);
      if (a[i] > 0)
         n++;
   }
   printf("\n n = %d\n", n);
   getch();
   return 0;
}
Добавлено через 1 минуту
Цитата Сообщение от vndtta Посмотреть сообщение
у тебя генерируюстя только целые числа
Вовсе нет, я же делю все на длину диапазона
0
0 / 0 / 0
Регистрация: 23.10.2011
Сообщений: 17
25.10.2011, 12:01  [ТС] 9
Никак не компилируется и все опять из-за этой строчки
0
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
25.10.2011, 12:03 10
Цитата Сообщение от Mashylya1 Посмотреть сообщение
Никак не компилируется и все опять из-за этой строчки
Еще раз ее скопируйте, доделал там кое-что. P.S. плохо без компилятора...
0
1552 / 918 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
25.10.2011, 12:06 11
А разве не размер массива лежит в диапазоне [3;20]?
0
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
25.10.2011, 12:07 12
Цитата Сообщение от neske Посмотреть сообщение
А разве не размер массива лежит в диапазоне [3;20]?
Может быть, но это не страшно, какой размер введет, такой массив и получится)
0
0 / 0 / 0
Регистрация: 23.10.2011
Сообщений: 17
25.10.2011, 12:09  [ТС] 13
Цитата Сообщение от Thinker Посмотреть сообщение
Еще раз ее скопируйте, доделал там кое-что. P.S. плохо без компилятора...
теперь компилирует но ответ выдает не правильный, т.е. если мы вводим 5-он в ответе и выдает 5, а не сумму положительных чисел, сами числа он выкидывает, но вместо их суммы ставит вводимое с клавы число.
0
237 / 210 / 29
Регистрация: 08.06.2011
Сообщений: 467
25.10.2011, 12:10 14
Цитата Сообщение от Thinker Посмотреть сообщение
Может быть, но это не страшно, какой размер введет, такой массив и получится)
У вас элементы в диапазоне от 3 до 20, и нужно
Цитата Сообщение от Mashylya1 Посмотреть сообщение
Подсчитать сумму положительных чисел.
в таком случае n будет всегда равно size
0
93 / 69 / 22
Регистрация: 17.10.2011
Сообщений: 235
25.10.2011, 12:12 15
Цитата Сообщение от Thinker Посмотреть сообщение
C
1
2
3
4
...
      a[i] = (1.0*(rand()%(B-A+1)) + A) / (1.0*(B - A));
...
}
Добавлено через 1 минуту


Вовсе нет, я же делю все на длину диапазона
молодец, добавил 1.0
только смотри, что получается
rand()-целое(я имею ввиду не тип выражения)
rand()%(B-A+1) - целое от 0 до 17
rand()%(B-A+1)+A - целое от 3 до 20
и после деления на интерфал ты получишь вещественное, но не случайное вещественное, а представимое в виде дроби i/18, где i целое от 3 до 20, т.е. генерируется только 18 чисел
0
Эксперт С++
 Аватар для Thinker
4267 / 2241 / 203
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
25.10.2011, 12:14 16
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
#include<stdlib.h>
#include<stdio.h>
#include<time.h>
#include<conio.h>
#define A -100
#define B 100
 
int main()
{
   double *a, sum;
   int i, n, size;
   srand(time(NULL));
   scanf("%d", &size);
   a = (double *)malloc(size*sizeof(*a));
   for (sum = i = 0; i < size; i++)
   {
      a[i] = (1.0*(rand()%(B-A+1)) + A) / (1.0*(B - A));
      printf("%.2f ", a[i]);
      if (a[i] > 0)
         sum += a[i];
   }
   printf("\n sum = %.2f\n", sum);
   getch();
   return 0;
}
Добавлено через 1 минуту
Цитата Сообщение от vndtta Посмотреть сообщение
молодец, добавил 1.0
только смотри, что получается...
Я согласен с вами. Если Честно, просто делаю несколько дел одновременно и под руками нет компилятора)
1
237 / 210 / 29
Регистрация: 08.06.2011
Сообщений: 467
25.10.2011, 12:16 17
Цитата Сообщение от Thinker Посмотреть сообщение
P.S. плохо без компилятора...
Цитата Сообщение от Thinker Посмотреть сообщение
Я согласен с вами. Если Честно, просто делаю несколько дел одновременно и под руками нет компилятора)
http://codepad.org/DITm6Pnt
1
0 / 0 / 0
Регистрация: 23.10.2011
Сообщений: 17
25.10.2011, 12:20  [ТС] 18
Цитата Сообщение от Thinker Посмотреть сообщение
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
#include<stdlib.h>
#include<stdio.h>
#include<time.h>
#include<conio.h>
#define A -100
#define B 100
 
int main()
{
   double *a, sum;
   int i, n, size;
   srand(time(NULL));
   scanf("%d", &size);
   a = (double *)malloc(size*sizeof(*a));
   for (sum = i = 0; i < size; i++)
   {
      a[i] = (1.0*(rand()%(B-A+1)) + A) / (1.0*(B - A));
      printf("%.2f ", a[i]);
      if (a[i] > 0)
         sum += a[i];
   }
   printf("\n sum = %.2f\n", sum);
   getch();
   return 0;
}
Добавлено через 1 минуту


Я согласен с вами. Если Честно, просто делаю несколько дел одновременно и под руками нет компилятора)
Большое спасибо)))
0
93 / 69 / 22
Регистрация: 17.10.2011
Сообщений: 235
25.10.2011, 12:32 19
Цитата Сообщение от Thinker Посмотреть сообщение
C
1
2
3
4
5
6
7
8
#include<stdlib.h>
...
#define A -100
#define B 100
 
...
      a[i] = (1.0*(rand()%(B-A+1)) + A) / (1.0*(B - A));
...
Добавлено через 1 минуту


Я согласен с вами. Если Честно, просто делаю несколько дел одновременно и под руками нет компилятора)
размер генерируемого интервала так и остался 1, просто теперь 200 чисел генерируется
всеравно не понимаю к чему так усложнять
0
 Аватар для alkagolik
1599 / 622 / 113
Регистрация: 15.07.2011
Сообщений: 3,548
25.10.2011, 12:56 20
Thinker, а память освобождать кто будет?
0
25.10.2011, 12:56
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.10.2011, 12:56
Помогаю со студенческими работами здесь

Задачка с одномерным массивом. Отбор по условию
Всем привет. Мне дана такая задача с массивом. Дан массив. Вывести на экран индексы i, j, k, при которых a = a + a. То есть, если дан...

Задачка к курсовой (действия с массивом вещественных чисел)
Пытался выучить Си++ с помощью умных книг, но пока как-то не очень, вот прошу помочь с этой задачей, а заодно расскажите как сделать так,...

Задачка с одномерным массивом.Найти количество удвоенных нечётных чисел
Помогите пожалуйста. Вот текст задания: Даны целые числа a1,a2..an.Известно что a1&gt;0 и что среди a2..an есть хотя бы одно...

Задачка с одномерным массивом. Определить количество одноразрядных, двухразрядных и трёхразрядных чисел в процентном отношении
Имеется задача: Создать массив из 50 случайных чисел в диапазоне от 0 до 200. Определить количество одноразрядных, двухразрядных и...

Задачка с массивом и задачка с формулами Ньютона и Лагранжа
Прошу помочь решить две задачи


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

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

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Опции темы

Новые блоги и статьи
Использование кэша Laravel - полный гайд
bytestream 18.02.2025
Кэширование - один из наиболее эффективных способов повышения производительности веб-приложений. В современном мире, где скорость загрузки страниц напрямую влияет на удержание пользователей и. . .
Создаем REST API в Laravel с аутентификацией через Passport
bytestream 18.02.2025
Разработка современных веб-приложений все чаще требует создания надежного и хорошо структурированного API. REST API стал стандартом де-факто для построения взаимодействия между клиентской и серверной. . .
Пайплайны в Laravel - полный гайд
bytestream 18.02.2025
Разработка современных веб-приложений часто требует обработки сложных процессов, состоящих из множества последовательных шагов. Например, при создании системы комментариев может потребоваться. . .
Как правильно использовать @required в Symfony
bytestream 18.02.2025
При разработке приложений на Symfony мы часто сталкиваемся с необходимостью внедрения зависимостей. Фреймворк предоставляет несколько способов управления этим процессом, и одним из таких инструментов. . .
Система безопасности в Laravel: возможности и примеры
Wired 18.02.2025
Каждый день появляются новые виды атак и уязвимостей, которые могут поставить под угрозу конфиденциальные данные пользователей и функционирование всей системы. В этом контексте выбор надежного. . .
Давайте сравним Django и Laravel
Wired 18.02.2025
Django и Laravel - два мощных инструмента, которые часто сравнивают между собой. Оба фреймворка предлагают разработчикам богатый набор возможностей для создания масштабируемых веб-приложений, но. . .
Laravel или React - что лучше?
Wired 18.02.2025
В разработке веб выбор правильного инструмента часто определяет успех всего проекта. Особенно интересным представляется сравнение Laravel и React - двух популярных технологий, которые часто. . .
Laravel 11: новые возможности, гайд по обновлению
Wired 18.02.2025
Laravel 11 - это новая масштабная версия одного из самых популярных PHP-фреймворков, выпущенная в марте 2024 года. Эта версия продолжает традицию внедрения передовых технологий и методологий. . .
Миграции в Laravel
Wired 18.02.2025
Разработка веб-приложений на Laravel неразрывно связана с управлением структурой базы данных. При работе над проектом часто возникает необходимость вносить изменения в схему базы данных - добавлять. . .
Аутентификация в Laravel
Wired 18.02.2025
В современном мире веб-разработки безопасность пользовательских данных становится критически важным аспектом любого приложения. Laravel, как один из самых популярных PHP-фреймворков, предоставляет. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru