Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Программирование. Ступени успешной карьеры. Авторы: Кузнецов М.В., Симдянов И.В. C++. Мастер-класс в задачах и примерах. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Разное

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: Простая проверка наличия в списке
 
 автор: OLi   (12.02.2013 в 13:55)   письмо автору
 
 

Нужно найти элемент в списке. Если существует - то вернуть false; если нет то вернуть true
Вот что имею - но работает не правильно. Где оплошность?
Private Function Valida() As Boolean
        Dim status As Boolean = False
        Dim LastStatus As Boolean = True
        Dim i As Integer = 0
        For Each wItem In mConnessioneCollect
            If (wItem.Trim() <> Name.Text.Trim() And LastStatus = True) Then
                status = True
            Else
                LastStatus = False
            End If
            i = i + 1
        Next
        If i = 0 Then
            status = True
        Else
            status = False
        End If
        Return status
    End Function

  Ответить  
 
 автор: CrazyAngel   (12.02.2013 в 15:29)   письмо автору
 
   для: OLi   (12.02.2013 в 13:55)
 

Я не знаю что это за язык но

Private Function Valida() As Boolean
        Dim status As Boolean = True
        For Each wItem In mConnessioneCollect
            If (wItem.Trim() == Name.Text.Trim())
                status = False
            End If
         Next
        Return status
    End Function


И откуда береться Name.Text? Зачем нужна переменная i?


в вашем алгоритме ошибка, там увеличиваться i+ всегда, по идеи вы написали плохой алгоритм на узнавание еслть ли хоть 1 элемент.

  Ответить  
 
 автор: cheops   (12.02.2013 в 20:53)   письмо автору
 
   для: CrazyAngel   (12.02.2013 в 15:29)
 

>Я не знаю что это за язык
Basic )))

  Ответить  
 
 автор: DJ Paltus   (12.02.2013 в 21:36)   письмо автору
 
   для: CrazyAngel   (12.02.2013 в 15:29)
 

А в таком случае не надо ли порвать цикл, если значение уже найдено?
не status = False, а сразу return False?

  Ответить  
 
 автор: CrazyAngel   (12.02.2013 в 21:39)   письмо автору
 
   для: DJ Paltus   (12.02.2013 в 21:36)
 


Private Function Valida() As Boolean
        For Each wItem In mConnessioneCollect
            If (wItem.Trim() == Name.Text.Trim())
                return False;
            End If
         Next
        Return True;
    End Function 


хей!)

  Ответить  
 
 автор: CrazyAngel   (12.02.2013 в 21:38)   письмо автору
 
   для: CrazyAngel   (12.02.2013 в 15:29)
 

и да лучше использовать не Name.Text.Trim(), а сделать переменную результат этой функции, чтоб каждый раз ее не вызывать

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования