Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Псевдокод] Задача на массивы 
:(
    Опции темы
Mar
Дата 14.10.2006, 13:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 13
Регистрация: 24.8.2006

Репутация: нет
Всего: нет



Здравствуйте.

Ай нид хэлп, ни магу решить задачу.

Вобщем вот задание

Сформировать и вывести на печать массив B(15), элементы которого принадлежат интервалу [-35;40].
Найти произведения отрицательных элементов и сумму элементов, кратных 3-м и имеющих нечетный индекс.

Как задать интервал [-35;40] ?

Если кому не сложно, напишите задачу в общем виде..

PM MAIL WWW   Вверх
Kuvaldis
Дата 14.10.2006, 13:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


механик-вредитель
***


Профиль
Группа: Участник Клуба
Сообщений: 1189
Регистрация: 16.6.2006
Где: Минск

Репутация: 32
Всего: 61



Mar
Цитата

Как задать интервал [-35;40] ?

Цитата

Сформировать и вывести на печать массив B(15), элементы которого принадлежат интервалу [-35;40].

const
    HIGH = 40;
   LOW = -35;

Цикл по всем элементам. Для каждого элемента B[i] массива проверяешь: если B[i] >=LOW и B[i] <= HIGH, то печать

 

Это сообщение отредактировал(а) Kuvaldis - 14.10.2006, 13:12


--------------------
Помни - когда ты спишь, враг не дремлет
Спи чаще и дольше, изматывай врага бессоницей
PM MAIL ICQ   Вверх
volvo877
Дата 14.10.2006, 14:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2073
Регистрация: 15.11.2004

Репутация: 34
Всего: 116



Цитата(Kuvaldis @  14.10.2006,  12:09 Найти цитируемый пост)
Для каждого элемента B[i] массива проверяешь: если B[i] >=LOW и B[i] <= HIGH, то печать

А зачем?

Код
If (B[i] + 35) In [0 .. 75] then

по-моему, лучше использовать... 
PM MAIL   Вверх
Kuvaldis
Дата 14.10.2006, 15:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


механик-вредитель
***


Профиль
Группа: Участник Клуба
Сообщений: 1189
Регистрация: 16.6.2006
Где: Минск

Репутация: 32
Всего: 61



volvo877
Цитата

А зачем?


код Pascal/Delphi    
1:    
If (B[i] + 35) In [0 .. 75] then    

по-моему, лучше использовать... 


А если диапазон будет больше, чем размерность 1 байта (256 элементов для множества) ?
Твой вариант, как всегда, красив, но на этот раз  не для общего случая smile 


--------------------
Помни - когда ты спишь, враг не дремлет
Спи чаще и дольше, изматывай врага бессоницей
PM MAIL ICQ   Вверх
volvo877
Дата 14.10.2006, 16:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2073
Регистрация: 15.11.2004

Репутация: 34
Всего: 116



Цитата(Kuvaldis @  14.10.2006,  14:01 Найти цитируемый пост)
А если диапазон будет больше, чем размерность 1 байта
Давай не будем заниматься предварительной оптимизацией "подо все случаи"... В задании явно указан интервал, зачем нужно рассматривать какие-то общие случаи?

"Premature optimization is the root of all evil" © Д.Кнут...

Кстати, для общей информации - твой вариант ошибочен в общем случае. Хочешь доказательство - в приват... Не будем засорять тему...
PM MAIL   Вверх
Oleg_Ci
Дата 14.10.2006, 17:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Friend
**


Профиль
Группа: Участник
Сообщений: 485
Регистрация: 28.5.2006
Где: Новосиб.обл.

Репутация: 25
Всего: 30



Код

#include <stdio.h>
#include <stdlib.h>
#define len 15

int main(int argc, char *argv[] )
{
    int matrix[len] = { -35, -10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 -4, 25, 45 },
        i, sum_minus = 0, k3 = 0;

    for ( i=0; i<len; i++ )
        if ( matrix[i] < 0 ) 
            sum_minus += matrix[i];// printf("sum_minus = %d\n", matrix[i]);
        else if ( matrix[i]%3 == 0 && i%2 == 0 ) 
            k3 += matrix[i];// printf("k3 = %d\n", matrix[i]);

    printf("\n\nSumma minus element = %d\nSumma element/3 = %d\n\n", sum_minus, k3 );

    system("pause");
    return 0;
}


PM MAIL   Вверх
Ofer
Дата 15.10.2006, 00:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 293
Регистрация: 15.10.2006
Где: КривбаСС

Репутация: нет
Всего: 5



Вот код на Турбо Паскале (v 7.1)

uses CRT;
var
  B : array [-35..40] of Integer;
  i,P,S : Integer;
begin
  ClrScr;
  P := 1;
  S := 0;
  Randomize;
  for i := 0 to 14 do
  begin
    B[i] := Random(10) - 5;
    Write(B[i]:3,'  ');
    if B[i] < 0 then
    P := P * B[i];
    if (B[i] mod 3 = 0) and (Odd(i)) then
    S := S + B[i];
  end;
  WriteLn;
  WriteLn('Произведение отрицательных чисел = ',P);
  WriteLn('Сумма чисел равных трем с нечетным индексом = ',S);
  ReadLn;
end.

Удачи! Надеюсь помогло.
PM MAIL ICQ   Вверх
volvo877
Дата 15.10.2006, 00:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2073
Регистрация: 15.11.2004

Репутация: 34
Всего: 116



Ofer, читаем внимательно:

Цитата(Mar @  14.10.2006,  12:02 Найти цитируемый пост)
Сформировать и вывести на печать массив B(15), элементы которого принадлежат интервалу [-35;40].
Элементы, а не индексы... Чувствуешь разницу?


PM MAIL   Вверх
Ofer
Дата 15.10.2006, 19:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 293
Регистрация: 15.10.2006
Где: КривбаСС

Репутация: нет
Всего: 5



Ну да, натупил.

Тогда достаточно изменить строку

  B : array [0..14] of Integer;

А числа и так задаются в указаном диапозоне smile

    B[i] := Random(10) - 5;

Но при желании можно тоже изменить:

    B[i] := Random(75) - 35;
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.1033 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.