Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [VB6] Поиск одинаковых чисел 
:(
    Опции темы
Чуччи
  Дата 30.10.2011, 14:03 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 5.11.2010

Репутация: нет
Всего: нет



Привет всем!
Моя задачка:
Определите и выведите на экран множество целых чисел находящихся одновременно в строках массива 2*5
Вот что у меня получилось:
Код

Dim i, j, k, g, h, l As Integer
    Dim a(,) As Integer
    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
        RichTextBox1.Text = ""
        i = 2
        j = 5
        ReDim a(0 To i - 1, 0 To j - 1)
        For n = 0 To i - 1
            For m = 0 To j - 1
                a(n, m) = Rnd(20) * 10 - 2
                If m = j - 1 Then
                    RichTextBox1.Text = RichTextBox1.Text + Str(a(n, m)) + vbCrLf
                Else
                    RichTextBox1.Text = RichTextBox1.Text + Str(a(n, m)) + " "
                End If
            Next
        Next
        For n = 0 To i - 1
            For m = 0 To j - 1
                l = 0
                For g = 0 To i - 1
                    For h = 0 To j - 1
                        If a(n, m) = a(g, h) And ((g <> n) or (h <> m)) Then
                            l = l + 1
                           RichTextBox2.Text = RichTextBox2.Text + Str(a(n, m)) + " "
                                Else
                           RichTextBox2.Text = RichTextBox2.Text + Str(a(n, m)) + vbCrLf
                        End If
                    Next
                Next
            Next
        Next
        End Sub


но выводит не понятно что
PM MAIL   Вверх
iff
Дата 30.10.2011, 17:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Администратор
**


Профиль
Группа: Участник
Сообщений: 949
Регистрация: 23.3.2007

Репутация: 3
Всего: 16



Цитата(Чуччи @  30.10.2011,  14:03 Найти цитируемый пост)
    Dim a(,) As Integer


Цитата(Чуччи @  30.10.2011,  14:03 Найти цитируемый пост)
        i = 2
        j = 5
        ReDim a(0 To i - 1, 0 To j - 1)

Зачем?
Код

Dim a(1, 4) As Integer

***
Цитата(Чуччи @  30.10.2011,  14:03 Найти цитируемый пост)
RichTextBox1

Зачем? Можно использовать просто textbox со свойством multiline=true.
***

Цитата(Чуччи @  30.10.2011,  14:03 Найти цитируемый пост)
                If m = j - 1 Then
                    RichTextBox1.Text = RichTextBox1.Text + Str(a(n, m)) + vbCrLf
                Else
                    RichTextBox1.Text = RichTextBox1.Text + Str(a(n, m)) + " "
                End If

Не надо. После вывода массива будут выводится другие данные - перевод строки нужен.
***
Зачем нужна переменная l (эль)?
Цитата(Чуччи @  30.10.2011,  14:03 Найти цитируемый пост)
находящихся одновременно в строках 

Т.е. например если массив емеет вид
Код

1 2 7 8 2
7 8 3 3 9

Ты вовидится не (2, 7, 8, 3), а (2, 3). Так?
... а может быть и наоборот: (7, 8). Сейчас даже подумал - последний вариант наверно самый правильный.
***
Тогда так:
Для конкретного случая (когда строки всего 2)
Код

For I = 0 To 4
    For J = 0 To 4
        If I <> J And A(0, I) = A(1, J) Then Text1.Text = Text1.Text + A(0, I) + vbCrLf
    Next J
Next I

Для общего случая можно так:
Код

For N = LBound(A, 1) To UBound(A, 1)
    For M = N + 1 To UBound(A, 1)
        For I = LBound(A, 2) To UBound(A, 2) 
            For J = LBound(A, 2) To UBound(A, 2)
                If I <> J And A(N, I) = A(M, J) Then Text1.Text = Text1.Text + A(0, I) + vbCrLf
            Next J
        Next I
    Next M
Next N

Однако, и там, и там возможен вариант, что если в страх повторяются значения несколько раз например:
Код

5 6 1 8 1
1 7 8 2 0

При обработке этого массива будет выведено: (1, 1, 8) вместо (1, 8). Вы можете доработать программу в этом плане - например можно использовать динамический массив для добавления новых элементов множества повторяющихся чисел.
Пример:
Код

Sub AddElement (Array As Variant, NewElement As Variant)
    Dim Element As Variant, Exist As Boolean
    For Each Element In Array
        If NewElement = Element Then
            Exist = True
            Exit For
        End If
    Next Element
    If Not Exist Then
        Redim Preserve Array(UBound(Array) + 1)
        Array(UBound(Array)) = NewElement
    End If
End Sub

Эта процедура добавляет элемент в массив только когда его там нет.

Это сообщение отредактировал(а) iff - 30.10.2011, 17:13


--------------------
DOS... Синей пеленой экран заполнил чистый DOS 
Мышь... Стала вдруг квадратной, потеряла форму мышь... 
Я разбил окно, девяностопятое мастдайное окно, 
И поставил DOS, и тогда увидел: Это счастье, — вот оно.  
PM MAIL WWW   Вверх
Чуччи
  Дата 30.10.2011, 17:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 14
Регистрация: 5.11.2010

Репутация: нет
Всего: нет



понятно

Это сообщение отредактировал(а) Чуччи - 30.10.2011, 17:36
PM MAIL   Вверх
Akina
Дата 30.10.2011, 22:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Советчик
****


Профиль
Группа: Модератор
Сообщений: 20581
Регистрация: 8.4.2004
Где: Зеленоград

Репутация: 17
Всего: 454



Для домашних заданий, курсовых, существует "Центр Помощи".

Тема перенесена! 


--------------------
 О(б)суждение моих действий - в соответствующей теме, пожалуйста. Или в РМ. И высшая инстанция - Администрация форума.

PM MAIL WWW ICQ Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

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

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0734 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.