![]() |
Здравствуйте, гость ( Вход | Регистрация )
![]() |
Гость_aligatr-kil_* |
![]()
Сообщение
#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(); } |
|
|
![]() |
![]()
Сообщение
#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_* |
![]()
Сообщение
#3
|
Guests ![]() |
ппц ты слепой! Код for( int j = i; j < strlen(str)-1; j++) str[i] = str[i+1];//сдвигаем хвост SiMM уже заметил. У тебя цикл по j! Даже с циклом по j всё равно сохраняется та ошибка, не говоря уже о том что правильный сдвиг, при котором данные цикл отпадает, был приведён в моём посте. |
|
|
![]()
Сообщение
#4
|
|
PAUK-NET.RU TEAM ![]() Группа: Admin Сообщений: 4,715 Регистрация: 11.7.2005 Из: ЮЗР Пользователь №: 3 ![]() |
|
|
|
Гость_Smacker_* |
![]()
Сообщение
#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_* |
![]()
Сообщение
#6
|
Guests ![]() |
спасибо всем большое !!!
Сообщение отредактировал Gobbs - Jan 7 2008, 13:38 |
|
|
![]() ![]() |
![]() |
Текстовая версия | Сейчас: 19th June 2025 - 19:13 |