Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/9: Рейтинг темы: голосов - 9, средняя оценка - 4.56
0 / 0 / 0
Регистрация: 20.10.2012
Сообщений: 55

Определить содержится ли в строке А строка Б, если да, то вывести номер позиции

07.10.2013, 19:20. Показов 2040. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Даны строки a и b. Определить содержится ли в строке А строка Б, если да, то вывести номер позиции.

Нужно решить задачу c применением Length и циклов for.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
07.10.2013, 19:20
Ответы с готовыми решениями:

Даны две строки: S1 и S2. Проверить, содержится ли строка S2 в строке S1. Если да, то вывести номер позиции, н
Даны две строки: S1 и S2. Проверить, содержится ли строка S2 в строке S1. Если да, то вывести номер позиции, начиная с которой S2...

Даны строки S и S нулевое.Проверить, содержится ли строка S нулевое в строке S. Если содержится, то вывести TRUE, если не содержится, то FALSE.
Помогите с такой вот программой пожалуйста... Даны строки S и S нулевое.Проверить, содержится ли строка S нулевое в строке S. Если...

Ввести две символьных строки. Выполнить поиск второй строки в первой и вывести номер позиции, с которой вторая строка содержится в первой.
Ввести две символьных строки. Выполнить поиск второй строки в первой и вывести номер позиции, с которой вторая строка содержится в первой. ...

7
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
07.10.2013, 19:40
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
static int SubstringPosition(string baseString, string subString)
        {
            int position = 0;
 
            for (int i =0, j = 0; i < baseString.Length; i++)
            {
                if(baseString[i]==subString[j])
                {
                    if(j==0)
                    {
                        position = i+1;
                    }
 
                    if (j==subString.Length-1)
                    {
                        return position;
                    }
                    j++;
                }
            }
            return 0;
        }
0
0 / 0 / 0
Регистрация: 20.10.2012
Сообщений: 55
07.10.2013, 19:44  [ТС]
оу, я такую не объясню, не похоже на начальный уровень. С преподом писали сегодня, но она была попонятней, правда побольше.
0
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
07.10.2013, 19:52
Да что тут объяснять, все дубово...
Я немного исправил там, посмотрите внимательнее.

Добавлено через 2 минуты
Плюс это еще вы меня ограничили, так то там еще меньше кода требуется
0
0 / 0 / 0
Регистрация: 20.10.2012
Сообщений: 55
07.10.2013, 19:57  [ТС]
Цитата Сообщение от n1l Посмотреть сообщение
Да что тут объяснять, все дубово...
Я немного исправил там, посмотрите внимательнее.

Добавлено через 2 минуты
Плюс это еще вы меня ограничили, так то там еще меньше кода требуется
Объясните пожалуйста
0
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
07.10.2013, 20:06
Цитата Сообщение от dragster Посмотреть сообщение
Объясните пожалуйста

Кликните здесь для просмотра всего текста


C#
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
//на вход принимаем две строки, главную и подстроку
static int SubstringPosition(string baseString, string subString)
        {
//это индекс позиции который мы хотим вернуть, если подстрока была найдена
            int position = 0;
 //тут цикл по главной строке, можно заметить, что объявлены два счетчика
//счетчик j можно вынести и поставить перед циклом, в корне ничего не изменится
//но я люблю все счетчики в одном месте определять
            for (int i =0, j = 0; i < baseString.Length; i++)
            {
//тут проверка на совпадение по символам
                if(baseString[i]==subString[j])
                {
//если совпадение по первому элементу подстроки
//запоминаем позицию
//так как позиция у здоровых людей нумеруется с еденицы, а все массивы и индексаторы с нуля
//вносим соответствующую поправку и увеличиваем значение на 1
                    if(j==0)
                    {
                        position = i + 1;
                    }
 //если вся подстрока все таки нашлась в базовой строке
//возврашаем позицию нашего первого совпадения
                    if (j==subString.Length-1)
                    {
                        return position;
                    }
                    j++;
                }
            }
//если ничего не совпало, то возвращаем 0 как знак, что совпадений нет.
            return 0;
        }



Так что берите свои сто рублей в ручки и идите покупайте книги

эту
и вот эту
0
Заблокирован
07.10.2013, 20:40
C#
1
2
3
4
5
6
7
8
9
10
  static int MyFunc(string init, string search)
        {
            for (int i = 0, j = 0; i < init.Length; i++)
                if (init[i] == search[j])
                {
                    if (++j == search.Length) return i - search.Length+1;
                }
                else j = 0;
            return -1;
        }
0
 Аватар для n1l
136 / 138 / 18
Регистрация: 26.07.2010
Сообщений: 911
07.10.2013, 20:54
Вот плюс у меня еще и ошибка, забыл j обнулить при несовпадении.

Добавлено через 40 секунд
Цитата Сообщение от dragster Посмотреть сообщение
Давай вебмани
Мне не нужно, спасибо

Добавлено через 1 минуту
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
static int SubstringPosition(string baseString, string subString)
        {
            int position = 0;
 
            for (int i =0, j = 0; i < baseString.Length; i++)
            {
                if(baseString[i]==subString[j])
                {
                    if(j==0)
                    {
                        position = i;
                    }
 
                    if (j==subString.Length-1)
                    {
                        return position;
                    }
                    j++;
                }
               j = 0; //ошибочку подправил.
            }
            return 0;
        }
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.10.2013, 20:54
Помогаю со студенческими работами здесь

Функция определяющая номер позиции, начиная с которой в строке содержится последнее вхождение подстроки
Описать функцию PosLast(s1, s) целого типа, возвращающую номер позиции, начиная с которой в строке s содержится последнее вхождение...

Функция целого типа, возвращающая номер позиции с которой в строке s содержится последнее вхождение подстроки s1
Описать функцию PosLast(s1, s) целого типа, возвращающую номер позиции, начиная с которой в строке s содержится последнее вхождение...

Описать функцию целого типа, возвращающую номер позиции, с которой в строке содержится последнее вхождение подстроки
Описать функцию PosLast (subs,s,k) целого типа,возвращающую номер позиции, с которой в строке s содержится последнее вхождение подстроки...

Дана строка, содержащая латинские буквы и скобки. Если скобки расставлены правильно - вывести 0. Иначе - номер позиции, где есть ошибочная скобка
Дана строка, содержащая латинские буквы и круглые скобки. Если скобки расставлены правильно (то есть каждой открывающей соответству-ет одна...

Вывести порядковый номер слова максимальной длины и номер позиции в строке, с которой оно начинается
как вывести на экран порядковый номер слова максимальной длины и номер позиции в строке, с которой оно начинается ?


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru