Здравствуйте, гость ( Вход | Регистрация )
| Гость_aligatr-kil_* |
Dec 25 2007, 21:32
Сообщение
#1
|
|
Guests |
Помогите пожалуйсто исправить программу : Удалите из слова все буквы, совпадающие с последней буквой.
Код #include <iostream.h>
#include <stdio.h> #include <conio.h> void main () { int i; int j; char str[100]; cin>>str[i]; char sym = str[strlen(str)-1];//запомнили последний for( int i = 0; i < strlen(str); i++) if( str[i] == sym )// находими нужный символ for( int j = i; j < strlen(str)-1; j++) str[i] = str[i+1];//сдвигаем хвост cout << str[i]; getch(); } |
|
|
|
![]() |
Dec 27 2007, 20:08
Сообщение
#2
|
|
![]() Продвинутый пользователь ![]() ![]() ![]() Группа: Posters Сообщений: 183 Регистрация: 29.6.2007 Из: Moscow-Чебоксары-Auckland Пользователь №: 7,397 |
Типичная ошибка для чайника - сдвигая массив ты "перепрыгиваешь" по i одну букву, так как она из i+1 перемещается в i, а в следующей итерации цикла ты уже увеличиваешь i, и когда у тебя встречается пара целевых букв для сдвига - одну ты пропустишь. Как вариант - --i; каждый раз как выполняешь сдвиг. Маленькое дополнение - сдвигать гораздо удобнее при помощи вызова strcpy(str+i,str+i+1); ЗЫ ты вообще щачем удаляешь что-то из целевой строки? Ты же выводишь посимвольно, так и выводи символ если он не совпал и выводи если совпал, а строку вообще трогать незачем. ппц ты слепой! Код for( int j = i; j < strlen(str)-1; j++) str[i] = str[i+1];//сдвигаем хвост SiMM уже заметил. У тебя цикл по j! |
|
|
|
| Гость_Ireul_* |
Dec 28 2007, 04:21
Сообщение
#3
|
|
Guests |
ппц ты слепой! Код for( int j = i; j < strlen(str)-1; j++) str[i] = str[i+1];//сдвигаем хвост SiMM уже заметил. У тебя цикл по j! Даже с циклом по j всё равно сохраняется та ошибка, не говоря уже о том что правильный сдвиг, при котором данные цикл отпадает, был приведён в моём посте. |
|
|
|
Dec 28 2007, 08:52
Сообщение
#4
|
|
|
PAUK-NET.RU TEAM Группа: Admin Сообщений: 4,715 Регистрация: 11.7.2005 Из: ЮЗР Пользователь №: 3 |
|
|
|
|
| Гость_Smacker_* |
Dec 29 2007, 11:49
Сообщение
#5
|
|
Guests |
Ну, я конечно не уверен, что авторская задумка была именно такая, но если расставить фигурные скобки и исправить индексирование во втором цикле, то в принципе вырисовывается нечто работоспособное:
Код #include <iostream>
using namespace std; void main () { char str[100]; cin>>str; char sym = str[strlen(str)-1]; for( unsigned int i = 0; i < strlen(str); i++) { if( str[i] == sym ) { unsigned int j = i; for(; j < strlen(str)-1; j++) { str[j] = str[j+1]; } str[j] = 0; } } cout << str; } |
|
|
|
aligatr-kil Помогите пожалуйсто исправить программу Dec 25 2007, 21:32
SiMM Цитата(aligatr-kil @ Dec 25 2007, 21... Dec 25 2007, 22:33
Ireul Типичная ошибка для чайника - сдвигая массив ты ... Dec 27 2007, 02:21
aligatr-kil спасибо всем большое !!! Jan 7 2008, 01:24
Snowm@n Цитата(Smacker @ Dec 29 2007, 11:49) Ну, ... Jan 31 2008, 11:01
Amp Мои две копейки - в коде разбираться не хочу, но б... Dec 27 2007, 23:04![]() ![]() |
|
Текстовая версия | Сейчас: 27th November 2025 - 23:50 |