Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RusFAQ.ru: Программирование на Basic / VBA


Хостинг Портала RusFAQ.ru:
MosHoster.ru - Профессиональный хостинг на Windows 2008

РАССЫЛКИ ПОРТАЛА RUSFAQ.RU

Чемпионы рейтинга экспертов в этой рассылке

Moryarty
Статус: 10-й класс
Рейтинг: 361
∙ повысить рейтинг >>
Шичко Игорь
Статус: Студент
Рейтинг: 248
∙ повысить рейтинг >>
Grigory
Статус: Студент
Рейтинг: 44
∙ повысить рейтинг >>

/ КОМПЬЮТЕРЫ И ПО / Языки программирования / Basic/VBA

Выпуск № 825
от 18.11.2008, 13:35

Администратор:Калашников О.А.
В рассылке:Подписчиков: 253, Экспертов: 26
В номере:Вопросов: 1, Ответов: 4

Нам важно Ваше мнение об этой рассылке.
Оценить этот выпуск рассылки >>

Вопрос № 150367: здравствуйте! помогите написать программу! Задача:Дано натуральное число, определить колличество цифр 3 в нём. Заранее спасибо!...


Вопрос № 150.367
здравствуйте! помогите написать программу!

Задача:Дано натуральное число, определить колличество цифр 3 в нём.

Заранее спасибо!
Отправлен: 12.11.2008, 21:44
Вопрос задала: Кочеткова Анастасия (статус: Посетитель)
Всего ответов: 4
Мини-форум вопроса >>> (сообщений: 2)

Отвечает: Коровин Александр
Здравствуйте, Кочеткова Анастасия!
Предлагаю Вам преобразовать переменную с числом в строковое значение, а затем сравнить его посимвольно с строкой "3".

Dim Chislo ' Исследуемое число
Dim strChislo ' Число, преобразованное в строку
Dim KolSimv ' Количество символов в строке
Dim Kol_3 ' Количество цифр 3

Kol_3=0
strChislo=CStr(Chislo)
KolSimv=Len(strChislo)
For i=1 To kolSimv
If Mid(strChislo,i,1)="3" Then
Kol_3=Kol_3+1
End If
Next
strMessege="Количество цифр 3 в числе "+strChislo+" равно "+CStr(Kol_3)
MsgBox strMessege



Ответ отправил: Коровин Александр (статус: 5-й класс)
Ответ отправлен: 13.11.2008, 08:33

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 235342 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Отвечает: megaloman
    Здравствуйте, Кочеткова Анастасия!
    Предлагаю еще один вариант решения (в приложении) Вашей задачи без преобразования исходного числа в строку.
    Так как рассылка VBA, то и проверял работу в VBA Excel
    Ввод исходного числа и выво результата не написал - Вы не указали, для какой версии Basic ставится задача

    Приложение:

    ---------
    Нет времени на медленные танцы

    Ответ отправил: megaloman (статус: Практикант)
    Ответ отправлен: 13.11.2008, 11:27

    Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 235371 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Отвечает: PsySex
    Здравствуйте, Кочеткова Анастасия!
    Если среда разработки VB6 то решение в 1 строчку:-)
    Код:
    Dim nNum As Long
    nNum = 135337333
    MsgBox UBound(Split(Str(nNum), "3"))

    ---------
    Bom Shankar!
    Ответ отправил: PsySex (статус: Специалист)
    Ответ отправлен: 13.11.2008, 12:44

    Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 235378 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Отвечает: Тесленко Евгений Алексеевич
    Здравствуйте, Кочеткова Анастасия!
    Прдлагаю для обозрения и свой вариант:
    Код:
    Function countSymbol(s$, sSymb$) As Integer
    Do While InStr(s, sSymb) > 0
    countSymbol = countSymbol + 1
    s = Replace(s, sSymb, Empty, InStr(s, sSymb), 1)
    Loop
    End Function
    Sub start()
    MsgBox countSymbol(234133333, 3)
    End Sub
    хотя после ответа PsySex( ), он очень громоздкий.
    Евгений.
    Ответ отправил: Тесленко Евгений Алексеевич (статус: Практикант)
    Ответ отправлен: 13.11.2008, 21:16

    Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 235438 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Вы имеете возможность оценить этот выпуск рассылки.
    Нам очень важно Ваше мнение!
    Оценить этот выпуск рассылки >>

    Отправить вопрос экспертам этой рассылки

    Приложение (если необходимо):

    * Код программы, выдержки из закона и т.п. дополнение к вопросу.
    Эта информация будет отображена в аналогичном окне как есть.

    Обратите внимание!
    Вопрос будет отправлен всем экспертам данной рассылки!

    Для того, чтобы отправить вопрос выбранным экспертам этой рассылки или
    экспертам другой рассылки портала RusFAQ.ru, зайдите непосредственно на RusFAQ.ru.


    Форма НЕ работает в почтовых программах The BAT! и MS Outlook (кроме версии 2003+)!
    Чтобы отправить вопрос, откройте это письмо в браузере или зайдите на сайт RusFAQ.ru.

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров >>

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2008, Портал RusFAQ.ru, Россия, Москва.
    Авторское право: ООО "Мастер-Эксперт Про"
    Техподдержка портала, тел.: +7 (926) 535-23-31
    Хостинг: "Московский хостер"
    Поддержка: "Московский дизайнер"
    Авторские права | Реклама на портале

    ∙ Версия системы: 5.11 от 9.11.2008

    Яндекс Rambler's Top100
    RusFAQ.ru | MosHoster.ru | MosDesigner.ru
    RusIRC.ru | Kalashnikoff.ru | RadioLeader.ru

    В избранное