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

Задачка с массивом - C++

Восстановить пароль Регистрация
 
 
Mashylya1
0 / 0 / 0
Регистрация: 23.10.2011
Сообщений: 17
25.10.2011, 11:33     Задачка с массивом #1
Как решить эту задачу в Си?
Дан массив вещественных случайных чисел (размер массива определяет поль-зователь, но в диапазоне [3;20]). Подсчитать сумму положительных чисел.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Thinker
Эксперт C++
 Аватар для Thinker
4215 / 2189 / 150
Регистрация: 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;
}
Mashylya1
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]);
   }
}
Это что? Это ничего не компилируется
Thinker
Эксперт C++
 Аватар для Thinker
4215 / 2189 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
25.10.2011, 11:45     Задачка с массивом #4
Цитата Сообщение от Mashylya1 Посмотреть сообщение
Это что? Это ничего не компилируется
Не компилировал. Если есть ошибки, то сами, наверное, в состоянии исправить. Я там переделал кое-что.
Nursik77
 Аватар для Nursik77
273 / 233 / 21
Регистрация: 05.04.2011
Сообщений: 645
25.10.2011, 11:47     Задачка с массивом #5
Thinker, наверное имеется ввиду это: http://www.cyberforum.ru/cpp-beginners/thread10807.html
Mashylya1
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);???
vndtta
66 / 43 / 5
Регистрация: 17.10.2011
Сообщений: 146
Завершенные тесты: 1
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;
Thinker
Эксперт C++
 Аватар для Thinker
4215 / 2189 / 150
Регистрация: 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 Посмотреть сообщение
у тебя генерируюстя только целые числа
Вовсе нет, я же делю все на длину диапазона
Mashylya1
0 / 0 / 0
Регистрация: 23.10.2011
Сообщений: 17
25.10.2011, 12:01  [ТС]     Задачка с массивом #9
Никак не компилируется и все опять из-за этой строчки
Thinker
Эксперт C++
 Аватар для Thinker
4215 / 2189 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
25.10.2011, 12:03     Задачка с массивом #10
Цитата Сообщение от Mashylya1 Посмотреть сообщение
Никак не компилируется и все опять из-за этой строчки
Еще раз ее скопируйте, доделал там кое-что. P.S. плохо без компилятора...
neske
1419 / 786 / 55
Регистрация: 26.03.2010
Сообщений: 2,689
25.10.2011, 12:06     Задачка с массивом #11
А разве не размер массива лежит в диапазоне [3;20]?
Thinker
Эксперт C++
 Аватар для Thinker
4215 / 2189 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
25.10.2011, 12:07     Задачка с массивом #12
Цитата Сообщение от neske Посмотреть сообщение
А разве не размер массива лежит в диапазоне [3;20]?
Может быть, но это не страшно, какой размер введет, такой массив и получится)
Mashylya1
0 / 0 / 0
Регистрация: 23.10.2011
Сообщений: 17
25.10.2011, 12:09  [ТС]     Задачка с массивом #13
Цитата Сообщение от Thinker Посмотреть сообщение
Еще раз ее скопируйте, доделал там кое-что. P.S. плохо без компилятора...
теперь компилирует но ответ выдает не правильный, т.е. если мы вводим 5-он в ответе и выдает 5, а не сумму положительных чисел, сами числа он выкидывает, но вместо их суммы ставит вводимое с клавы число.
Net_Wanderer
235 / 208 / 19
Регистрация: 08.06.2011
Сообщений: 467
25.10.2011, 12:10     Задачка с массивом #14
Цитата Сообщение от Thinker Посмотреть сообщение
Может быть, но это не страшно, какой размер введет, такой массив и получится)
У вас элементы в диапазоне от 3 до 20, и нужно
Цитата Сообщение от Mashylya1 Посмотреть сообщение
Подсчитать сумму положительных чисел.
в таком случае n будет всегда равно size
vndtta
66 / 43 / 5
Регистрация: 17.10.2011
Сообщений: 146
Завершенные тесты: 1
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 чисел
Thinker
Эксперт C++
 Аватар для Thinker
4215 / 2189 / 150
Регистрация: 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
только смотри, что получается...
Я согласен с вами. Если Честно, просто делаю несколько дел одновременно и под руками нет компилятора)
Net_Wanderer
235 / 208 / 19
Регистрация: 08.06.2011
Сообщений: 467
25.10.2011, 12:16     Задачка с массивом #17
Цитата Сообщение от Thinker Посмотреть сообщение
P.S. плохо без компилятора...
Цитата Сообщение от Thinker Посмотреть сообщение
Я согласен с вами. Если Честно, просто делаю несколько дел одновременно и под руками нет компилятора)
http://codepad.org/DITm6Pnt
Mashylya1
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 минуту


Я согласен с вами. Если Честно, просто делаю несколько дел одновременно и под руками нет компилятора)
Большое спасибо)))
vndtta
66 / 43 / 5
Регистрация: 17.10.2011
Сообщений: 146
Завершенные тесты: 1
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 чисел генерируется
всеравно не понимаю к чему так усложнять
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.10.2011, 12:56     Задачка с массивом
Еще ссылки по теме:

Задачка с одномерным массивом. Определить количество одноразрядных, двухразрядных и трёхразрядных чисел в процентном отношении C++
C++ Массивом и динамическим массивом
C++ Задачка с одномерным массивом. Отбор по условию

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

Или воспользуйтесь поиском по форуму:
alkagolik
 Аватар для alkagolik
1510 / 616 / 79
Регистрация: 15.07.2011
Сообщений: 3,552
25.10.2011, 12:56     Задачка с массивом #20
Thinker, а память освобождать кто будет?
Yandex
Объявления
25.10.2011, 12:56     Задачка с массивом
Ответ Создать тему
Опции темы

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