Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 17.05.2011
Сообщений: 5

Перевод из Visual Basic в С++

16.10.2011, 19:14. Показов 1817. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Прошу вашей помощи. Так как я VB не изучал.
Можите помочь перевести из Visual Basic в С++

Visual Basic
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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
Sub ВолновоеУравнениеЯвнаяСхема()
Dim x() As Double, y() As Double, ynp1() As Double, ynm1() As Double
Dim h As Double, tau As Double, r As Double, a As Double
Dim hPr As Double, tauPr As Double, Tmax As Double, L As Double
Dim nn As Long, mm As Long, MPr As Long, a1 As Double, a2 As Double
Dim n As Long, m As Long, ngr As Integer
Dim t As Double, rr As Double, pi As Double
pi = Atn(1) * 4
’ Исходные данные для задачи
L = 1
a = 1 ’ Это скорость распространения волны
Tmax = 0.5 ’ Верхняя граница временной координаты
h = 0.01 ’ Это шаг по пространственной координате
r = 1 ’Параметр сетки
tau = r * h ’Это шаг по временной координате
hPr = 0.1 ’Шаг для вывода значений сеточной функции по координате x
tauPr = 0.1 ’ Это шаг вывода графиков по временной координате
’NPr = CLng(Tmax / tauPr) + 1 ’Число графиков
MPr= CLng(hPr/h) ’Через столько точек выводить результаты по оси Ox
mm = CLng(L/h) ’ Количество ячеек сетки по оси Ox
nn = CLng(Tmax/tau) ’Количество ячеек сетки по оси Ot
ReDim x(mm), y(mm), ynp1(mm), ynm1(mm) ’Размерность массивов
For m = 0 To mm
x(m) = h * m
’Подстановка начальных условий
’Нулевой временной слой
ynm1(m) = Sin(pi * x(m))
’Первый временной слой
y(m) = ynm1(m) + tau * 0.5 * Cos(0.5 * pi * x(m))
Next m
Dim NameSh As String ’Имя листа для вывода результатов и графиков
NameSh = "ВолновоеУравнение"
Sheets(NameSh).Select
Cells.Clear ’Очистить рабочий лист
Cells(1, 1) = "t\x"
Cells(2, 1) = "t=0"
ngr = 1 ’Номер текущего графика
For m = 0 To mm Step MPr
Cells(1, m \ MPr + 2) = CDbl(Format(x(m), "#0.00"))
Cells(ngr + 1, m \ MPr + 2) = CDbl(Format(ynm1(m), "#0.00"))
Cells(1, m \ MPr + 2).Interior.Color = RGB(220, 90, 220)
Next m
a1 = 2 * (1 - r ^ 2)
a2 = r ^ 2
For n = 2 To nn
t = tau * n
For m = 1 To mm - 1
ynp1(m) = a1 * y(m) + a2 * (y(m + 1) + y(m - 1)) - ynm1(m)
Next m
Call ГраничныеУсловияВолновое(ynp1, t, h, mm)
’Переставить активные временные слои для следующей итерации
For m = 0 To mm
ynm1(m) = y(m)
y(m) = ynp1(m)
Next m
’Записать решение на данном временном слое а
’Записываются с шагом tauPr
If Abs((ngr) * tauPr - t) < tau / 10 Then
ngr = ngr + 1
Cells(ngr + 1, 1) = "t=" + Format(t, "#0.00")
For m = 0 To mm Step MPr
Cells(ngr + 1, m \ MPr + 2) = CDbl(Format(y(m), "#0.00"))
Next m
End If
Next n
Range("a1:a" + Trim(Str(ngr + 1))).Interior.Color = _
RGB(220, 90, 220)
Dim NameDiagr As String ’Название диаграммы
NameDiagr = "Волновое уравнение"
Call ПостроитьГрафики(ngr, CInt(mm / MPr), NameSh, _
NameDiagr, 0, 1, 0, 1)
End Sub
Sub ГраничныеУсловияВолновое(ynp1() As Double, _
t As Double, h As Double, mm As Long)
Dim pi As Double
pi = Atn(1) * 4
ynp1(0) = 0 ’Левая граница
’Правая граница
ynp1(mm) = (ynp1(mm - 1) + h * _
0.1 * Sin(2 * pi * t)) / (1 + h)
End Sub
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.10.2011, 19:14
Ответы с готовыми решениями:

Перевод из C++ в Visual Basic
Здравствуйте. Прошу вашей помощи. #include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;cmath&gt; using namespace std; void main() {...

Перевод в Visual Basic
Решить нелинейное уравнение методом простых итераций Ln(x)-x+1.8 = 0 На отрезке По этому уравнению есть программка в Pascal ...

Перевод с Visual Basic на C#
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click Dim text As String =...

1
28 / 27 / 7
Регистрация: 11.06.2011
Сообщений: 387
17.10.2011, 11:38
Так это VBA. Он работает с Excel (судя по range). Сомневаюсь, что тут так просто переведешь на C++
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.10.2011, 11:38
Помогаю со студенческими работами здесь

Перевод из Pascal в Visual Basic
Добрый день! Я пыталась перевести код программы из Pascal в Visual Basic. Дело в том, что курсовую надо сдавать в Visual Basic, а я его...

Перевод программы с Visual Basic 6.0
Option Explicit Private Type malType X As Single Y As Single Vx As Single Vy As Single R As Single ...

Перевод программы с С++ на Visual Basic
Ребят, помогите пожалуйста имеется прога, написанная на С++, необходимо перевести ее на бейсик. мозгов не хватает допереть это :D Оба...

Перевод кода с Visual Basic в C++
Помогите перевести код с Visual Basic в C++ :wall: For i = 2 To n Line (P(i - 1).x * 10 + Line1.X1, -(P(i - 1).y) * 10 +...

Перевод программы C++ -> Visual Basic
Друзья, помогите пож. перевести код с языка C++ в Visual Basic, в котором я не очень хорошо разбираюсь. №1. Составить блок-схему и...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru