Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
-1 / 0 / 0
Регистрация: 30.12.2022
Сообщений: 20

Пограмма на языке VBA для нахождения среднего арифметического

24.12.2024, 18:49. Показов 711. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, препод сказал мне переписать данный код, но чтобы он брал значения из ячеек Эксель, а не через массивы(Я не нашёл в редакторе VBA и выбрал VB, пожалуйста, не ругайте!!):
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
Sub Lab7()
    Dim x(1 To 10) As Double 
    Dim s As Single 
    s = 0
    x(1) =-0.1
    x(2) = 0.05
    x(3) = 0.7
    x(4) = 0.8
    x(5) = -1.5
    x(6) = 0.2
    x(7) = 0.4
    x(8) = - 1
    x(9) = 0.1
    x(10) = 1.5
    For i=Lbound(x) To Ubound(x) 
           s=s+x(i) 
    Next i
s=s/10
Cells(3,2)= "s=" & s
End Sub
Я переписал код. Все значения "x" у меня в ячейках Эксель:
Visual Basic
1
2
3
4
5
6
7
8
9
Sub Lab7
Dim x As Single, y As Single 
Dim s As Single 
s=0
For x = 1 To 10 Step 1 
       If Cells(x, 2) < 0 Then: s = s + Cells(x, 2)
Next x
s = s / 10
Cells(13,1) = "s=" & s
Этот код работает, но препод сказал, что он неправильный, указав на то, что у меня x - скалярная величина. Скажите, пожалуйста, где у меня ошибка в коде? Я что-то не понимаю как именно надо написать.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.12.2024, 18:49
Ответы с готовыми решениями:

Функция для нахождения среднего арифметического
Нужно написать функцию, принимающую произвольное число аргументов и вычисляющую их среднее арифметическое (при вычислениях проверять:...

Создать модуль для нахождения среднего арифметического 4х чисел
создать модуль для нахождения среднего арифметического 4х чисел

Процедуры и функции: функция для нахождения среднего арифметического стека
дана структура данных - стек. Написать функцию, вычисляющую среднее арифмитичеcкое элементов стека. Программа должна: создавать стек,...

8
sleep
 Аватар для I can
4914 / 4529 / 837
Регистрация: 13.04.2015
Сообщений: 9,663
24.12.2024, 19:12
Цитата Сообщение от Paul1 Посмотреть сообщение
где у меня ошибка в коде?
А задание какое?
0
-1 / 0 / 0
Регистрация: 30.12.2022
Сообщений: 20
24.12.2024, 19:20  [ТС]
Блин, извините, забыл написать:
"Даны два массива с элементами x, y, i = 1,2,3,..., 10. Xi =[-0,1 0,05 0,7 0,8 - 1,5 0,2 0,4 - 1 0,1 1,5]. Найдите среднее арифметическое чисел Xi с помощью VBA.
Вы не знаете как редактировать заданный вопрос на форуме? Я не просто не разобрался.
0
sleep
 Аватар для I can
4914 / 4529 / 837
Регистрация: 13.04.2015
Сообщений: 9,663
24.12.2024, 19:27
Цитата Сообщение от Paul1 Посмотреть сообщение
как редактировать заданный вопрос на форуме?
Можно и так оставить, ничего страшного.
Короче, надо массивы заполнить с листа Эксель, а потом вычислять.
А второй-то массив какой?
Цитата Сообщение от Paul1 Посмотреть сообщение
Найдите среднее арифметическое чисел Xi
Среднее арифметическое каких элементов массива? Судя по предыдущим сообщениям, которые меньше 0 ?
0
-1 / 0 / 0
Регистрация: 30.12.2022
Сообщений: 20
24.12.2024, 19:39  [ТС]
Yi=[0,1 0,05 0,7 0,8 -1,5 0,2 0,4 -1 0,1 1,5] - я не стал писать эту таблицу, потому что она не нужна.
Так-то в задании написано, что просто среднее арифметическое ряда Xi, но тут моя, видимо, ошибка. Почему-то препод на это внимание не обратил.
0
sleep
 Аватар для I can
4914 / 4529 / 837
Регистрация: 13.04.2015
Сообщений: 9,663
24.12.2024, 19:44
Цитата Сообщение от Paul1 Посмотреть сообщение
Yi=[0,1
Массивы одинаковые что-ли?
0
428 / 332 / 61
Регистрация: 29.06.2019
Сообщений: 493
24.12.2024, 20:18
Visual Basic
1
Range("a13") = WorksheetFunction.Average(Range("b1:b10"))
0
349 / 190 / 108
Регистрация: 01.04.2020
Сообщений: 537
24.12.2024, 21:08
Цитата Сообщение от Paul1 Посмотреть сообщение
Так-то в задании написано, что просто среднее арифметическое ряда Xi, но тут моя, видимо, ошибка. Почему-то препод на это внимание не обратил.
видимо препод обращает в первую очередь внимание на то что вы ему преподнесли и пытается вас привести к тому, чтобы вы устранили ошибки
Цитата Сообщение от Paul1 Посмотреть сообщение
препод сказал мне переписать данный код, но чтобы он брал значения из ячеек Эксель, а не через массивы
с преподом вашим говорили вы но правильно-ли интерпретитуете его слова - еще вопрос

Вариант 1.
У меня сомнения что препод вас хочет увести от работы с массивами.
Из ячеек эксель можно данные загрузить в массив и дальше массив обработать (почти) не измененным кодом.

Вариант 2.
Допустим задача в том, чтобы вы попробовали работу напрямую с ячейками.
Ваш переписанный код тогда если бы и выдал правильный итог (а он не выдает),
то в вашем коде вы переменную х переквалифицировали на значение строки,
она в вашем коде не соответсвует тому значению, который ей принадлежит
это к тому:
Цитата Сообщение от Paul1 Посмотреть сообщение
Этот код работает, но препод сказал, что он неправильный, указав на то, что у меня x - скалярная величина.
(но деградировали вы статус переменной х и тем запутываете и первоначальную задачу и
всех смотриящих которые пытаюся разобрать ваш переписанный код)
1
 Аватар для Angry Old Man
2995 / 738 / 310
Регистрация: 26.03.2022
Сообщений: 1,379
Записей в блоге: 1
24.12.2024, 22:00
Paul1, Можно воспользоваться стандартной функцией листа Excel, как сделал SergioJek, а можно написать свою функцию, которую можно использовать в подпрограмме, а также на листе. Файл прилагаю, уберите только расширение .txt
Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
Sub Paul1()
    Range("B14") = Aver(Range("B3:B12"))
    Range("D14") = Aver(Range("D3:M3"))
End Sub
 
Function Aver(X As Range) As Variant
    Dim Xi As Variant
    Aver = 0
    For Each Xi In X
        Aver = Aver + Xi
    Next
    Aver = Aver / X.Count
End Function
Миниатюры
Пограмма на языке VBA для нахождения среднего арифметического  
Вложения
Тип файла: txt Книга1.xlsm.TXT (14.0 Кб, 0 просмотров)
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.12.2024, 22:00
Помогаю со студенческими работами здесь

Написать код для нахождения среднего арифметического целых чисел
Написать код для нахождения среднего арифметического всех целых чисел от 1 до 1000 тремя циклами

Функция для нахождения среднего арифметического листьевых вершин дерева
Дано S-выражение, представляющее дерево вида «(РебенокЛевый Родитель РебенокПравый)» с числами в качестве вершин. Определить функцию для...

Написать функцию,для нахождения среднего арифметического отрицательных элементов
Нужно написать функцию,для нахождения среднего арифметического отрицательных элементов матрицы,стоящих до максимального элемента матрицы ...

Функция для нахождения среднего арифметического пяти чисел типа FLOAT
Написать программу, которая использует функцию для нахождения среднего арифметического пяти чисел типа FLOAT, вводимых с клавиатуры...

Составить функцию для нахождения среднего арифметического элементов одномерного массива
Пожалуйста помогите с заданием.Составить функцию для нахождения среднего арифметического элементов одномерного массива. Используя ее,...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru