搜尋

首頁  >  問答  >  主體

c++ - 字符串中删除特定字符的题目中,此处应该用s[j+1]还是s[j]

输入字符串s及待删除的字符ch,将s中所有与ch相同的字符都删除掉,输出删除后得到的新串。以下程序是直接在数组s中进行删除,得到的新串仍然在数组s中。

#include <iostream>
using  namespace  std;

int main( )
{
    char  s[81], ch;
    int k,j;
    cin>>s;
    cin>>ch; //输入待删除的字符(不允许允许为空格符)
    //以下k代表s中每个字符的下标
    //j代表未删除(保留)字符应放在s中新的位置下标
    for(k=j=0;s[k]!='\0';k++)
        if(s[k]!=ch)
        {
            s[j]=s[k];
            __(1)__;
        }
    __(2)__='\0'; //得到的新串末尾要放结束符
    cout<<s<<endl;
    return 0;
}

第一个空填j++;
第二个空填s[j+1]还是s[j];
我认为是s[j],但是网上的答案是s[j+1],如果后者是对的,那么前者在什么情况下出错?

ringa_leeringa_lee2773 天前1089

全部回覆(1)我來回復

  • 迷茫

    迷茫2017-04-17 14:40:44

    應該是s[j]
    先看循環內,如果沒有遇到等於輸入的ch,那麼j==k是一直成立的。
    如果遇到了ch,那麼k自增了,但是j沒有變,也就是遇到了幾次ch,那麼k就比j大幾。
    假如有nch在字串中,那麼出循環的時候k-j == n應該成立。此時k的位置是,還是應該是s[j] = s[k],此時s[k] == ',所以s[j] == ''

    回覆
    0
  • 取消回覆