Форум программистов, компьютерный форум, киберфорум
Java SE (J2SE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 01.08.2015
Сообщений: 104

Работа со строками

22.01.2018, 21:32. Показов 825. Ответов 16
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет. Проблема в следующем: из данной строки, в которой может находится любое количество специального символа, удалить символы, находящиеся слева и справа от него. Пример: sm*eil*ly -> siy. Пробовал без StringBuilder, пытался и с ним, в частности использовать метод delete() для удаления символов. Сама проблема в том, что программа корректно удаляет символы для индекса первого вхождения спец. символа, а второй более не трогает. В программе рассматриваю три случая: когда нет спец.символа, когда он один и когда больше одного. Для третьего случая код не справляется с задачей Код громоздкий, не могу пока что придумать как сделать лучше. Подскажите, как лучше выполнить эту задачу, решение мне не нужно, только подсказка. Код прилагаю ниже.
Java
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
public static void main(String[] args) {
        String str = "sm*eil*ly";
        StringBuilder sb = new StringBuilder(str);
        
        String newSt = "";
        int count = 0;
        
        for (int i = 0; i < str.length(); i++) {
            if (str.charAt(i) == '*') {
                count++;
            }
        }
        
        int index = 0;
        
        switch(count) {
        case 0:
            System.out.println(str);
            break;
        case 1:
            for (int j = 0; j < str.length()-1; j++) {
                if (str.charAt(j) == '*') {
                    index = j;
                }
            }
            newSt += str.substring(0, index-1) + str.substring(index+2);
            System.out.println(newSt);
            break;
        }
        //"sm*eil*l*y"
        
        if (count > 1) {
            for (int i = 0; i < str.length() - 1; i++) {
                if (str.charAt(i) == '*') {
                    int index1 = str.indexOf('*');
                    int index2 = str.lastIndexOf('*');
                    sb.delete(index1-1, index2+1);
                }
            }
            System.out.println(sb.toString());
        } 
        
        
        
        int index1 = 0;
        
        
    /*  в этом случае код для двух спец.символов работает, но если их больше, чем 2 - нет.
     * 
     * 
     * for (int i = 0; i < str.length()-1; i++) {
            if (str.charAt(i) == '*' && i != 0) {
                index1 = i;
                System.out.println(index1);
                sb.delete(index1-1,index1+2);
                System.out.println(sb.toString());
                break;
            }
        }
        
        for (int j = 0; j < sb.length() - 1; j++) {
            if (sb.charAt(j) == '*') {
                index1 = j;
                System.out.println(index1);
                sb.delete(index1-1,index1+2);
                System.out.println(sb.toString());
                break;
            }
        } */
        
        
    }
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.01.2018, 21:32
Ответы с готовыми решениями:

Работа со строками, заполнить компоненты строками из файла
Привет! Нужна помощь в заполнении формы В общем, есть форма отправки письма. У нее есть 2 функции, сохранить письмо и открыть письмо (на...

Работа со строками. Функции работы со строками
Дана строка символов. В заданном тексте определить позицию первой точки ‘ . ‘.

Работа со строками(операции над строками)
Пусть дана последовательность, содержащая от 2 до 50 слов, в каждом из которых от 1 до 8 строчных латинских букв; между соседними словами...

16
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
22.01.2018, 22:44
Подсказка - replaceAll + регулярное выражение

Добавлено через 3 минуты
1 строчка

Добавлено через 31 минуту
Kirillgo, получилось?
1
0 / 0 / 0
Регистрация: 01.08.2015
Сообщений: 104
22.01.2018, 22:45  [ТС]
Да, я пытался через этот метод сделать, но не получалось. Сейчас решение получается только если спец.символ не идет последовательно:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
String str = "sm***eil*ly";
        StringBuilder sb = new StringBuilder(str);
        
        for (int i = 0; i < sb.length()-2; i++) {
            if (sb.charAt(i) == '*') {
                sb.replace(i-1, i+2, ".");
                System.out.println(sb); // для контроля примера
            }
        }
        
        String st = new String(sb);
        System.out.println(st.replace(".", "")); // для контроля примера
    }

То есть для случая "sm*eil*ly он выдает "siy", все верно. Для случая "sm***eil*ly" -> s*eiy. Я так понимаю, что он проходит единожды циклом по строке, пропуская один спец.символ. Как заставить его обработать всю строку без нагромождения циклов?
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
22.01.2018, 22:51
Введи логическую переменную, при выполнении if'а меняй ее, и оберни все это хозяйство while. Не знаю, как объяснить...

Добавлено через 2 минуты
Java
1
System.out.print("sm***eil*ly".replaceAll(".\\*+.", ""));
0
0 / 0 / 0
Регистрация: 01.08.2015
Сообщений: 104
22.01.2018, 22:57  [ТС]
Цитата Сообщение от iSmokeJC Посмотреть сообщение
".\\*+."
Как это называется?
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
22.01.2018, 22:58
Регулярное выражение
1
0 / 0 / 0
Регистрация: 01.08.2015
Сообщений: 104
22.01.2018, 23:07  [ТС]
Спасибо, почитаю про это.

Добавлено через 7 минут
Кстати, протестировал программку и вот что получается: при таких примерах как *stringy получаю точно такой же результат.
То есть надо добавить условие в код для таких ситуаций, но тогда все равно громоздко получается, ведь этот знак может быть где угодно в строке.
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
22.01.2018, 23:09
Да, косячок...
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7390 / 4817 / 1246
Регистрация: 30.03.2015
Сообщений: 13,667
Записей в блоге: 29
23.01.2018, 08:20
Kirillgo,
Java
1
2
3
4
5
6
7
8
9
String str = "sm!*@eil$ly";
        StringBuilder sb = new StringBuilder();
 
        for (char ch:str.toCharArray()) {
            if (Character.isLetter(ch)){
                sb.append(ch);
            }
        }
        System.out.println(sb);
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
23.01.2018, 12:30
Welemir1, тут фишка в том, чтоб удалить ещё соседние символы...
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7390 / 4817 / 1246
Регистрация: 30.03.2015
Сообщений: 13,667
Записей в блоге: 29
23.01.2018, 12:47
iSmokeJC, упс, мои извинения, не внимательно прочел задачу
0
 Аватар для Aviz__
2738 / 2047 / 507
Регистрация: 17.02.2014
Сообщений: 9,465
23.01.2018, 12:58
легче показать кодом, чем подсказывать словами, в данном случае.
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public static void main(String[] args) {
        StringBuilder sBox = new StringBuilder("sm*eil*ly");
        char delPoint = '*';
        int charInd = 1;
        int highBorderStrBox = sBox.length();
        while (charInd < highBorderStrBox) {
            if (sBox.charAt(charInd) == delPoint) {
                sBox.deleteCharAt(charInd + 1);
                sBox.deleteCharAt(charInd - 1);
                highBorderStrBox = sBox.length();
            }
            charInd++;
        }
 
        System.out.println(sBox);
    }
0
0 / 0 / 0
Регистрация: 01.08.2015
Сообщений: 104
23.01.2018, 13:15  [ТС]
А почему индексацию с 1 начинаем, а не с нуля?
0
 Аватар для Aviz__
2738 / 2047 / 507
Регистрация: 17.02.2014
Сообщений: 9,465
23.01.2018, 13:59
это же набросок))
чтобы не проверять, выход за границу, если специальный символ, например, был бы с индексом 0. тут и конечность, так же не учитывается.
0
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
23.01.2018, 18:39
Во!
Java
1
System.out.println(s.replaceAll(".?\\*+.?", ""));
0
0 / 0 / 0
Регистрация: 01.08.2015
Сообщений: 104
24.01.2018, 11:20  [ТС]
Я пока не пробовал твой вариант, потому что еще с регулярными выражениями не разбирался. Написал вот такой код, проблема в том, что не хочет в конце заменять спец. символы:
Java
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
34
35
36
37
38
39
40
public static void main(String[] args) {
        StringBuilder sb = new StringBuilder("sm*eil*ly");
        
        
        
        char symbol = '*';
        int delChar = 1;
        
        if (sb.length() == 0) {
            System.out.println(sb.toString());
        }
        
        for (int i = 0; i < sb.length()-1; i++) {
            if (sb.charAt(i) == symbol && i == 0 && sb.charAt(i+1) != symbol) {
                sb.replace(0, 2, "");
            } else if (sb.charAt(i) == symbol && i == sb.length()-1 && sb.charAt(i-2) != symbol) {
                sb.replace(sb.length()-2, sb.length()-1, "");
            }
 
    }
        
        int len = sb.length();
        
        while (delChar < len) {
            if (sb.charAt(delChar) == symbol) {
                sb.deleteCharAt(delChar+1);
                sb.deleteCharAt(delChar-1);
                len = sb.length();
            }
            delChar++;
        } 
        
        
        String str = new String(sb);
        if (str.contains("*")) {
            str.replace("*", "");
        }
        System.out.println(str);
 
}
Добавлено через 1 минуту
И меня смущает 17 строка, где последний и предпоследний символы надо убрать. Я корректно написал или нет? Потому что endIndex в данном методе не включительный, но тогда писать вместо него sb.length() ?
0
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
24.01.2018, 12:39
наверно можно упростить, лень думать
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
private static String removeSpecial(String s, char special) {
        StringBuilder sb = new StringBuilder();
        int lastIndex = s.length() - 1;
        for (int i = 0; i < s.length(); i++) {
            if (s.charAt(i) != special
                    && (i > 0 && s.charAt(i - 1) != special
                        || i == 0 && s.charAt(i) != special)
                    && (i < lastIndex && s.charAt(i + 1) != special
                        || i == lastIndex && s.charAt(i) != special)) {
                sb.append(s.charAt(i));
            }
        }
        return sb.toString();
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.01.2018, 12:39
Помогаю со студенческими работами здесь

Задание по темам: ООП, исключения, работа со строками (возможно применение коллекций List), работа с компоновщиком
ТЯЖЕЛО РАБОТАТЬ С КОМПОНОВЩИКОМ. БУДУ РАД ВАШИМ ОТВЕТАМ. 1. Ознакомиться с принципом работы структурного шаблона проектирования...

Работа со строками
1. Дано предложение. Подсчитать число всех точек, и заменить все точки на буквосочетание «тчк». 2. Дано слово, состоящее из нечетного...

Работа со строками
Помогите пжл. Только начинаю разбираться. В чем ошибка????? Разработать программу, которая вводит букву английского алфавита и...

Работа со строками
даны 5 гододов, расположить в порядке убывания числа букв. Я написал что похожее, но не работает))) И как сделать, чтобы названия городов...

Работа со строками
Дана строка. Преобразовать все строчные1|прописные2 латинские3|русские4 буквы в прописные1|строчные2.


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

Или воспользуйтесь поиском по форуму:
17
Ответ Создать тему
Новые блоги и статьи
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 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru