搜尋

首頁  >  問答  >  主體

c++ - 看不懂这段c语言代码的思路,目的是删除字符串1中与字符串2相同的字符

代码:

char *eliminate(char str1[], char str2[])
{
int i, j, k;
   for(i=j=0;str1[i];i++)
   {
for(k=0;str2[k] && str1[i]!=str2[k];k++); if(str2[k]== ‘\0’)
         str1[j++]=str1[i];
   }
str1[j]=‘\0’;
   return str1;
}

感觉根本就没给j赋值啊,也不知道str1[j++]=str1[i]是想做什么。。。求助大神

原问题:

• Write a program to read two strings as input and remove from string
1 all characters contained in string 2
• Example:

  • str1: “Olimpico”

  • str2: “Oio”

  • result: “lmpc”

答案全部代码

#include < stdio.h > 
#define MAXCAR 128
char * eliminate(char str1[], char b[]);
int main() {
    char str1[MAXCAR], str2[MAXCAR];
    printf(“Give me a string str1: ”);
    scanf(“ % s”, str1);
    printf(“Give me a string str2: ”);
    scanf(“ % s”, str2);
    printf(“str1 - str2 = % s\ n”, eliminate(str1, str2));
    return 0;
}

char * eliminate(char str1[], char str2[]) {
    int i, j, k;
    for (i = j = 0; str1[i]; i++) {
        for (k = 0; str2[k] && str1[i] != str2[k]; k++);
        if (str2[k] == ‘\0’)
            str1[j++] = str1[i];
    }
    str1[j] = ‘\0’;
    return str1;
}
PHPzPHPz2803 天前770

全部回覆(2)我來回復

  • 大家讲道理

    大家讲道理2017-04-17 13:08:30

    感覺根本沒給j賦值啊

    for(i=j=0;str1[i];i++)

    也不知道str1[j++]=str1[i]是想做什麼。 。 。求助大神

    其實很簡單,程式碼的思路就是一個位元組一個位元組的處理str1,i是正在讀取的位置,j是正在寫入的位置。如果i目前的字元在str2中存在了,那麼j就可以覆蓋他,因此不用++。所以只需要在寫的時候才j++,度的時候i總是++,這就是這句程式碼的意思。

    舉例

    str1 = abcbd
    str2 = b
    
    step 1. [i][j]abcbdrrreee
    step 2. a[i][j]bcbdrrreee
    step 3. a[j]b[i]cbdrrreee
    step 4. ac[j]c[i]bdrrreee
    step 5. ac[j]cb[i]drrreee
    step 6. acd[j]bd[i]rrreee
    step 7. acdrrreee[j]drrreee[i]
    

    到此就結束了。雖然str1裡面的字串是acd

    回覆
    0
  • ringa_lee

    ringa_lee2017-04-17 13:08:30

    你的程式碼我試了下運行不了,應該是一些中英文字符搞混了吧
    我幫你改了代碼,並且運行過了
    思路都寫在註釋裡了
    你的ID。 。 。

    #include <stdio.h> 
    #define MAXCAR 128
    char *eliminate(char str1[], char b[]);
    int main() {
        char str1[MAXCAR], str2[MAXCAR];
        printf("Give me a string str1: ");
        scanf("%s", str1);
        printf("Give me a string str2: ");
        scanf("%s", str2);
        printf("str1 - str2 =%s\n", eliminate(str1, str2));
        return 0;
    }
    
    char *eliminate(char str1[], char str2[]) {
        int i, j, k;
        for (i = j = 0; str1[i]; i++) {
            for (k = 0; str2[k] && str1[i] != str2[k]; k++);//这句代码为了找出str1[i]==str2[k]
            if(str2[k] == 'rrreee')//如果在str2中发现有与str1中相同的,但是却是'rrreee',那就代表其实str2中没有与str1中相同的字符
                str1[j++] = str1[i];//那么j就可以写入
            //else 出现了相同的就舍弃,j不写入
        }
        str1[j] = 'rrreee';//所有str1中的字符都检查过了,就添加一个'rrreee'收尾
        return str1;
    }

    回覆
    0
  • 取消回覆