VB нет.Переводчик азбуки Морзе: вырезайте правильные знаки с помощью Mid () и сопоставляйте их с буквой - PullRequest
0 голосов
/ 25 декабря 2018

Я пытаюсь перевести азбуку Морзе в текст на VB.net.Используя приведенный ниже код, некоторые буквы в тексте остаются непереведенными.Я полагаю, что проблема связана с «oddel», который должен указывать, сколько букв должно быть вырезано в Mid (morsC, i, oddel) при выборе регистра.Код должен быть в состоянии перевести это>…. / ./ .- .. / .- .. / --- / <в Hello. </p>

Что странно, что при переводе «Hello», первая буква »H "правильно вырезано как" .... / ", но оно не соответствует регистру" H "

'Hello = …./ ./ .-../ .-../ ---/
Sub EE15a()
    Dim veta As String, morsCod As String, st As String
    morsCod = InputBox("Enter the morse code.")
    veta = morsCodF(morsCod)
    st = "Preklad dle funkce " + Chr(10) + veta + Chr(10)
    MsgBox(st)
End Sub
Function morsCodF(morsC As String) As String
    Dim pismeno As String, znak As String
    Dim i As Integer, j As Integer, oddel As Integer
    Dim nasel As Boolean
    znak = "/"
    morsC = Trim(morsC)
    j = 1
    For i = 1 To (morsC.Length)
        i = j
        Do
            If Mid(morsC, j, 1) = znak Then
                oddel = j - oddel
                nasel = True
                Exit Do
            End If
            j = j + 1
        Loop Until nasel = True Or j > (morsC.Length)
        If i = 1 Then
            pismeno = (" " + Mid(morsC, i, oddel))
        Else
            pismeno = Mid(morsC, i, oddel)
        End If
        Select Case pismeno '" ...-/"
            Case " .-/" : morsCodF = morsCodF + " a"
            Case " -.../" : morsCodF = morsCodF + " b"
            Case " -.-./" : morsCodF = morsCodF + " c"
            Case " -../" : morsCodF = morsCodF + " d"
            Case " ./" : morsCodF = morsCodF + " e"
            Case " ..-./" : morsCodF = morsCodF + " f"
            Case " --./" : morsCodF = morsCodF + " g"
            Case " ..../" : morsCodF = morsCodF + " h"
            Case " ../" : morsCodF = morsCodF + " i"
            Case " .---/" : morsCodF = morsCodF + " j"
            Case " -.-/" : morsCodF = morsCodF + " k"
            Case " .-../" : morsCodF = morsCodF + " l"
            Case " --/" : morsCodF = morsCodF + " m"
            Case " -./" : morsCodF = morsCodF + " n"
            Case " ---/" : morsCodF = morsCodF + " o"
            Case " .--./" : morsCodF = morsCodF + " p"
            Case " --.-/" : morsCodF = morsCodF + " q"
            Case " .-./" : morsCodF = morsCodF + " r"
            Case " .../" : morsCodF = morsCodF + " s"
            Case " -/" : morsCodF = morsCodF + " t"
            Case " ..-/" : morsCodF = morsCodF + " u"
            Case " ...-/" : morsCodF = morsCodF + " v"
            Case " .--/" : morsCodF = morsCodF + " w"
            Case " -..-/" : morsCodF = morsCodF + " x"
            Case " -.--/" : morsCodF = morsCodF + " y"
            Case " --../" : morsCodF = morsCodF + " z"
            Case "#" : morsCodF = morsCodF + " "
        End Select
        nasel = False
        pismeno = ""
        j = j + 1
    Next
End Function

Код должен переводить все слово или предложение, но вместо этого переводит только часть текста.Например:…. / ./ .- .. / .- .. / --- / ожидаемое: «Hello», фактическое: «eo»

Ответы [ 4 ]

0 голосов
/ 26 декабря 2018

Словарь для быстрого поиска, String.Split для краткости и StringBuilder, чтобы не создавать новые строки на каждой итерации.

 Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        Dim s As String = GetTextFromMorse("..../ ./ .-../ .-../ ---/")
        Debug.Print(s)
 End Sub

 Private DictCode As New Dictionary(Of String, String) From
    {
        {".-", "a"},
        {"-...", "b"},
        {"-.-.", "c"},
        {"-..", "d"},
        {".", "e"},
        {"..-.", "f"},
        {"--.", "g"},
        {"....", "h"},
        {"..", "i"},
        {".---", "j"},
        {"-.-", "k"},
        {".-..", "l"},
        {"--", "m"},
        {"-.", "n"},
        {"---", "o"},
        {".--.", "p"},
        {"--.-", "q"},
        {".-.", "r"},
        {"...", "s"},
        {"-", "t"},
        {"..-", "u"},
        {"...-", "v"},
        {".--", "w"},
        {"-..-", "x"},
        {"-.--", "y"},
        {"--..", "z"},
        {"#", " "}
    }

Private Function GetTextFromMorse(input As String) As String
    Dim strArray() As String = input.Split({"/"}, StringSplitOptions.RemoveEmptyEntries)
    Dim sb As New StringBuilder
    For Each s In strArray
        sb.Append(DictCode(s.Trim))
    Next
    Return sb.ToString
End Function
0 голосов
/ 25 декабря 2018

Если вам нужно несколько букв в верхнем регистре, вам нужно предоставить дополнительную логику (например, первая буква всегда в верхнем регистре).Следующий код создает словарь с кодами и их буквами, анализирует строку кода Морзе с помощью Regex, извлекает коды один за другим и выбирает буквы на основе этих кодов.Я создал две версии - с Regex и Split.

Dim morse = New Dictionary(Of String, String) From
{
    {".-", "a"},
    {"-...", "b"},
    {"-.-.", "c"},
    {".", "e"},
    {"....", "h"},
    {".-..", "l"},
    {"---", "o"},
    {"#", " "}
}

Dim s = "..../ ./ .-../ .-../ ---/"

'// 1. REGEX
'// Search for '.', '-' and '#' in any combinations followed by '/'
Dim mc = Regex.Matches(s, "[\.\-#]+(?=/)")
'// Fetch each code from dictionary and concatenate them
Dim x = String.Join("", mc.Cast(Of Match).Select(Function(m) morse(m.Value)))

'// 2. SPLIT
'// Dim x = String.Join("", s.Split({"/"}, StringSplitOptions.RemoveEmptyEntries).
'//                           Select(Function(z) morse(z.Replace("/", "").Trim())))

Console.WriteLine(x)

'// Output: hello
0 голосов
/ 26 декабря 2018

Я думаю, что вы получите больше отзывов о коде, если добавите регистр по умолчанию для переключателя Select Case.

Select Case s
    Case " .-" : morsCodF = morsCodF + " a"
    Case "#" : morsCodF = morsCodF + " "
    Case Else : morsCodF = morsCodF + " WRONG! "
End Select
  1. Проверьте, работает ли эта строка oddel = j - oddel как ожидается.
    Исходя из имеющейся у вас логики oddel должно быть количество символов после ранее найденного / символа.Если это так, то вычисление oddel = j - oddel выглядит неправильно.
    Поскольку вы обновляете i текущим j, вычисление должно быть oddel = j - (i -1)

  2. Проверка Forloop.
    Поскольку i обновляется каждый раз с текущим значением j, код создаст один дополнительный цикл, который выдаст «неправильное» значение.

  3. Другие предложения.
    Декодирование азбуки Морзе в текст - это простое отображение одной строки в другую.
    В vb.net Dictionary(Of String, String) может быть хорошим инструментом для этого.

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

Function FromMorse(code As String) As String
    Const DELIMETER As Char = " "c
    Static Secret As New Dictionary(Of String, String) From
    {
        {".-", "a"},
        {"-...", "b"},
        {"-.-.", "c"},
        {"-..", "d"},
        {".", "e"},
        {"..-.", "f"},
        {"--.", "g"},
        {"....", "h"},
        {"..", "i"},
        {".---", "j"},
        {"-.-", "k"},
        {".-..", "l"},
        {"--", "m"},
        {"-.", "n"},
        {"---", "o"},
        {".--.", "p"},
        {"--.-", "q"},
        {".-.", "r"},
        {"...", "s"},
        {"-", "t"},
        {"..-", "u"},
        {"...-", "v"},
        {".--", "w"},
        {"-..-", "x"},
        {"-.--", "y"},
        {"--..", "z"},
        {"#", " "}
    }

    Return code.Split(DELIMETER).
                Select(Function(c) Secret(c)).
                Aggregate(New StringBuilder(), Function(b, c) b.Append(c)).
                ToString()
End Function

Использование

Dim code = ".... . .-.. .-.. --- # .-- --- .-. .-.. -.."
Dim decoded = FromMorse(code)

Console.WriteLine(decoded) ' => "hello world"
0 голосов
/ 25 декабря 2018

разделить строку morsCod с "/" в качестве разделителя

Public Class Form1
    Sub EE15a()
        Dim veta As String, morsCod As String, st As String
        'morsCod = InputBox("Enter the morse code.")
        morsCod = "..../ ./ .-../ .-../ ---/ --"
        morsCod = " .-/ -.../ -.-./ -../ ./ ..-./ --./ ..../ ../ .---/ -.-/ .-../ --/ -./ ---/ .--./ --.-/ .-./ .../ -/ ..-/ ...-/ .--/ -..-/ -.--/ --.."
        veta = morsCodF(morsCod)
        st = "Preklad dle funkce " + Chr(10) + veta + Chr(10)
        MsgBox(st)
    End Sub
    Function morsCodF(morsC As String) As String
        Dim arr As String() = morsC.Split("/"c)
        For Each s As String In arr
            Select Case s
                Case " .-" : morsCodF = morsCodF + " a"
                Case " -..." : morsCodF = morsCodF + " b"
                Case " -.-." : morsCodF = morsCodF + " c"
                Case " -.." : morsCodF = morsCodF + " d"
                Case " ." : morsCodF = morsCodF + " e"
                Case " ..-." : morsCodF = morsCodF + " f"
                Case " --." : morsCodF = morsCodF + " g"
                Case " ...." : morsCodF = morsCodF + " h"
                Case " .." : morsCodF = morsCodF + " i"
                Case " .---" : morsCodF = morsCodF + " j"
                Case " -.-" : morsCodF = morsCodF + " k"
                Case " .-.." : morsCodF = morsCodF + " l"
                Case " --" : morsCodF = morsCodF + " m"
                Case " -." : morsCodF = morsCodF + " n"
                Case " ---" : morsCodF = morsCodF + " o"
                Case " .--." : morsCodF = morsCodF + " p"
                Case " --.-" : morsCodF = morsCodF + " q"
                Case " .-." : morsCodF = morsCodF + " r"
                Case " ..." : morsCodF = morsCodF + " s"
                Case " -" : morsCodF = morsCodF + " t"
                Case " ..-" : morsCodF = morsCodF + " u"
                Case " ...-" : morsCodF = morsCodF + " v"
                Case " .--" : morsCodF = morsCodF + " w"
                Case " -..-" : morsCodF = morsCodF + " x"
                Case " -.--" : morsCodF = morsCodF + " y"
                Case " --.." : morsCodF = morsCodF + " z"
                Case "#" : morsCodF = morsCodF + " "
            End Select
        Next
    End Function

    Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
        EE15a()
    End Sub
End Class
...