Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RusFAQ.ru: Информатика


Хостинг Портала RusFAQ.ru:
MosHoster.ru - Профессиональный хостинг на Windows 2008

РАССЫЛКИ ПОРТАЛА RUSFAQ.RU

Чемпионы рейтинга экспертов в этой рассылке

Botsman
Статус: Практикант
Рейтинг: 95
∙ повысить рейтинг >>
Копылов Александр Иванович
Статус: Практикант
Рейтинг: 49
∙ повысить рейтинг >>
Лысков Игорь Витальевич
Статус: Профессионал
Рейтинг: 44
∙ повысить рейтинг >>

/ НАУКА И ОБРАЗОВАНИЕ / Точные и естественные науки / Информатика

Выпуск № 159
от 21.05.2009, 17:35

Администратор:Калашников О.А.
В рассылке:Подписчиков: 177, Экспертов: 32
В номере:Вопросов: 1, Ответов: 2

Нам важно Ваше мнение об этой рассылке.
Оценить этот выпуск рассылки >>

Вопрос № 167422: Добрый день! Помогите понять что неправильно в проге для VBA? Задание такое - Дан массив из 10 чисел. посчитать сумму и произведение всех отрицательных элеменитов. Я написала так: Sub Prime4() Dim A(1 To 10) As Single, I, S, P As Integer, S1 As...


Вопрос № 167.422
Добрый день! Помогите понять что неправильно в проге для VBA? Задание такое - Дан массив из 10 чисел. посчитать сумму и произведение всех отрицательных элеменитов. Я написала так:
Sub Prime4()
Dim A(1 To 10) As Single, I, S, P As Integer, S1 As String
S = 0
P = 1
For I = 1 To 10
A(I) = InputBox("I=" + Str(I), "Ввод значений массива")
S1 = S1 + "" + Str(A(I))
If A(I) < 0 Then
P = 1
S = S + A(I)
P = P * A(I)
ElseIf A(I) > 0 Then
P = 0

End If
Next I
MsgBox "S1=" & S1, vbInformation, "Вывод эл-ов массива"
MsgBox "S=" & S, vbInformation, "Сумма отриц. элементов"
MsgBox "P=" & P, vbInformation, "Произв. отриц элементов"
End Sub

Если использовать
ElseIf A(I) > 0 Then
P = 0
то произведение везде выводится как 0, сколько бы чисел не было
Если эо убрать, то все получается правильно, кроме того случая, как отриц. чисел нет вообще. P выводится как 1
Отправлен: 16.05.2009, 17:27
Вопрос задала: Соколова Елизавета (статус: Посетитель)
Всего ответов: 2
Мини-форум вопроса >>> (сообщений: 2)

Отвечает: AlexanderZh
Здравствуйте, Соколова Елизавета!

Sub Prime4()
Dim A(1 To 10) As Single, I, S, P As Integer, S1 As String
S = 0
P = 1 0
For I = 1 To 10
A(I) = InputBox("I=" + Str(I), "Ввод значений массива")
S1 = S1 + "; " + Str(A(I))
If A(I) < 0 Then
P = 1
S = S + A(I)
if p=0 then P = A(I) else p=p*a(i)
ElseIf A(I) > 0 Then
P = 0

End If
Next I
MsgBox "S1=" & S1, vbInformation, "Вывод эл-ов массива"
MsgBox "S=" & S, vbInformation, "Сумма отриц. элементов"
MsgBox "P=" & P, vbInformation, "Произв. отриц элементов"
End Sub

Вот так должно все работать
---------
Простите меня, я больше так не буду...
Ответ отправил: AlexanderZh (статус: Специалист)
Ответ отправлен: 17.05.2009, 09:02

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 249314 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Отвечает: SFResid
    Здравствуйте, Соколова Елизавета!
    Другой вариант (ИМХО проще):
    Sub Prime4()
    Dim A(1 To 10) As Single, I, S, P As Integer, S1 As String
    S = 0
    P = 1
    For I = 1 To 10
    A(I) = InputBox("I=" + Str(I), "Ввод значений массива")
    S1 = S1 + "" + Str(A(I))
    If A(I) < 0 Then
    S = S + A(I)
    P = P * A(I)
    End If
    Next I
    If S = 0 Then P = 0

    MsgBox "S1=" & S1, vbInformation, "Вывод эл-ов массива"
    MsgBox "S=" & S, vbInformation, "Сумма отриц. элементов"
    MsgBox "P=" & P, vbInformation, "Произв. отриц элементов"
    End Sub
    Ответ отправил: SFResid (статус: Профессор)
    США, Силиконовая Долина
    ----
    Ответ отправлен: 18.05.2009, 00:42

    Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 249364 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Вы имеете возможность оценить этот выпуск рассылки.
    Нам очень важно Ваше мнение!
    Оценить этот выпуск рассылки >>

    Отправить вопрос экспертам этой рассылки

    Приложение (если необходимо):

    * Код программы, выдержки из закона и т.п. дополнение к вопросу.
    Эта информация будет отображена в аналогичном окне как есть.

    Обратите внимание!
    Вопрос будет отправлен всем экспертам данной рассылки!

    Для того, чтобы отправить вопрос выбранным экспертам этой рассылки или
    экспертам другой рассылки портала RusFAQ.ru, зайдите непосредственно на RusFAQ.ru.


    Форма НЕ работает в почтовых программах The BAT! и MS Outlook (кроме версии 2003+)!
    Чтобы отправить вопрос, откройте это письмо в браузере или зайдите на сайт RusFAQ.ru.

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров >>

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2009, Портал RusFAQ.ru, Россия, Москва.
    Авторское право: ООО "Мастер-Эксперт Про"
    Техподдержка портала, тел.: +7 (926) 535-23-31
    Хостинг: "Московский хостер"
    Поддержка: "Московский дизайнер"
    Авторские права | Реклама на портале

    ∙ Версия системы: 5.13 от 01.12.2008

    Яндекс Rambler's Top100
    RusFAQ.ru | MosHoster.ru | MosDesigner.ru
    RusIRC.ru | Kalashnikoff.ru | RadioLeader.ru

    В избранное