找回密碼 或 安全提問
 註冊
|註冊|登錄

伊莉討論區

搜索
發表文章前請先閱讀相關版規儲值後自動升級用戶組安全提問(回答) 和 永久尊貴會員 事宜
三上fate人妖overlord母乳世紀帝國流出
在地下城ibw 931z七零之改iptd 551midv 850蘇暢soe 602

休閒聊天興趣交流學術文化旅遊交流飲食交流家庭事務PC GAMETV GAME
熱門線上其他線上感情感性寵物交流家族門派動漫交流貼圖分享BL/GL
音樂世界影視娛樂女性頻道潮流資訊BT下載區GB下載區下載分享短片
電腦資訊數碼產品手機交流交易廣場網站事務長篇小說體育運動時事經濟
上班一族博彩娛樂

[繁]魔王軍最強的魔術

[繁]靠廢柴技能【狀態

[繁]關於我轉生變成史

[繁]我要【招架】一切

[簡]狼與辛香料 Merch

一句話 死好
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 2130|回復: 2
打印上一主題下一主題

[問題]字串刪除問題[複製鏈接]

Rank: 1

帖子
282
積分
163 點
潛水值
9370 米
跳轉到指定樓層
樓主
發表於 2015-1-12 12:27 AM|只看該作者|倒序瀏覽
本帖最後由 snowflying 於 2015-1-12 01:54 AM 編輯

題目是這樣: s1 , s2 均是字串 ,  將s1中所有出現於s2之字符均刪除.我是新手, 請高手能幫我看一下哪裡要改嗎...
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. void squeez(char s1[],char s2[])
  4. {
  5.      int i,j,k=0;
  6.      for(i=0;s1[i]!='\0';i++)
  7.      {
  8.          for(j=0;s2[j]!='\0';j++)
  9.          {
  10.              if(s1[i]!=s2[j])
  11.              {
  12.                  s1[k++]=s1[i];
  13.              }
  14.          }
  15.      }
  16.      s1[k]='\0';
  17.      print f("%s ",s1);
  18. }
  19. int main(int argc, char** argv)
  20. {
  21.      int i;
  22.      char a[100]="abcdefe",b[100]="fedcba";
  23.      squeez(a,b);
  24.      return 0;
  25. }
複製代碼
...
瀏覽完整內容,請先 註冊登入會員

點評

snowflying 先包程式碼,請查看版規部分  發表於 2015-1-12 12:39 AM
分享分享0收藏收藏0支持支持0
所有積分大於負-100的壞孩子,將可獲得重新機會成為懲罰生,權限跟幼兒生一樣。

使用道具檢舉

  尊貴會員

Melty Snow  雪靈

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

帖子
3228
積分
24427 點
潛水值
78470 米
頭香
發表於 2015-1-12 02:04 AM|只看該作者
所有積分大於負-100的壞孩子,將可獲得重新機會成為懲罰生,權限跟幼兒生一樣。
應該是判斷 s2 裡面的所有字元都不相符,才給值

if(s1[ i ] != s2[ j ])
{
    s1[k++] = s1[ i ];
}

這會造成每次去跟 s2[j] 比時,不相同就執行 s1[k++] = s1[ i ];
造成許多重複值,更慘的情況下,會造成無窮迴圈,與 buffer overflow

舉個例子 :
a[100] = "abc12de34f" , b[100] = "abcdef"

a[0] 與 b[0] 比較,相同,繼續比較下一個
...
瀏覽完整內容,請先 註冊登入會員
Melty Snow [雪靈]
若新密碼無法使用,可能是數據未更新。請使用舊密碼看看。

使用道具檢舉

Rank: 1

帖子
282
積分
163 點
潛水值
9370 米
3
發表於 2015-1-12 07:17 AM|只看該作者
如果發覺自己無法使用一些功能或出現問題,請按重新整理一次,並待所有網頁內容完全載入後5秒才進行操作。
snowflying 發表於 2015-1-12 02:04 AM
下載: 訪客無法瀏覽下載點,請先 註冊登入會員

應該是判斷 s2 裡面的所有字元都不相符,才給值

if(s1[ i ] != s2[ j ])

原來如此,讓我又多學了一課,感恩指教

使用道具檢舉

您需要登錄後才可以回帖 登錄 | 註冊

Powered by Discuz!

© Comsenz Inc.

重要聲明:本討論區是以即時上載留言的方式運作,對所有留言的真實性、完整性及立場等,不負任何法律責任。而一切留言之言論只代表留言者個人意見,並非本網站之立場,用戶不應信賴內容,並應自行判斷內容之真實性。於有關情形下,用戶應尋求專業意見(如涉及醫療、法律或投資等問題)。 由於本討論區受到「即時上載留言」運作方式所規限,故不能完全監察所有留言,若讀者發現有留言出現問題,請聯絡我們。有權刪除任何留言及拒絕任何人士上載留言,同時亦有不刪除留言的權利。切勿上傳和撰寫 侵犯版權(未經授權)、粗言穢語、誹謗、渲染色情暴力或人身攻擊的言論,敬請自律。本網站保留一切法律權利。
回頂部