Помогите с программой на VBA

программирование программы excel VBA

Даны действительные числа А и В. Если они оба неотрицательные, то заменить каждое из них его кубом, иначе отрицательные из них заменить их модулями.
У меня получилось:

Private Sub CommandButton1_Click()
a = InputBox("Введите А:")
b = InputBox("Введите B:")
If (a < 0) And (b < 0) Then
a = Abs(a)
b = Abs(b)
Else
a = a ^ 3
b = b ^ 3
End If
c = "a1=" + Str(a) + " b1=" + Str(b)
MsgBox (c)
End Sub
Private Sub CommandButton2_Click()
MsgBox ("Выполнил я ")
End Sub

Private Sub CommandButton3_Click()
UserForm1.Hide
End Sub

Примечание:
Проблема в том, что программа не берет модуль, если число отрицательное. НЕ пойму что не так сделал :(

Примечание:
Т.е. вводим например -12 вместо того чтобы просто взять модуль, программа возводит -12 в куб, а модуль не берет, а требуется просто взять модуль.

Примечание:
"отрицательные из них заменить их модулями." так как мне именно это условие задать, чтобы прога знала что если одно отрицательное а другое положительное то одно модуль второе куб? Прописать все 6 вариантов развития событий, т.е. 6 раз задать условие через IF ?

Примечание:
Т.е. Другого пути, кроме как задать все варианты чередования a,b нет ?
Ответы:
Только что проверил в VBA Excel 2010 — программа работоспособна.
> Проблема в том, что программа не берет модуль, если число отрицательное. НЕ пойму что не так сделал :(
Дело в том, что вы сами в операторе If прописали, что модуль каждого числа будет вычисляться только в случае, если ОБА числа, а и b, отрицательные. Если хотя бы одно число положительное, то ни один модуль вычисляться не будет.
По условию требовалось другое - "отрицательные из них заменить их модулями."
так надо
If (a > 0) And (b > 0) Then
  a = a ^ 3
  b = b ^ 3
Else
  a = Abs(a)
  b = Abs(b)
End If


11 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.