代码:
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;
}
大家讲道理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
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;
}