關於字元串 “*****AB**C*D*****” 中首碼、尾碼和中間 '*' 的處理

来源:http://www.cnblogs.com/LeoFeng/archive/2016/04/03/5349741.html
-Advertisement-
Play Games

一、刪除首碼 '*' 1 #include<iostream> 2 #include<cstdio> 3 4 using namespace std; 5 6 //主函數 7 int main() 8 { 9 char chr[20],*b,*p; //字元串緩衝區;字元串頭指針;字元串臨時指針 1 ...


一、刪除首碼 '*'

 1 #include<iostream>
 2 #include<cstdio>
 3 
 4 using namespace std;
 5 
 6 //主函數
 7 int main()
 8 {
 9     char chr[20],*b,*p; //字元串緩衝區;字元串頭指針;字元串臨時指針 
10     int chr_num=0,b_num=0; //輸入的字元串中字元的個數;輸入的字元串中首碼 * 的個數
11     int i;
12     
13     //輸入 
14     cout<<"Please input a string:"<<endl; 
15     gets(chr);
16     
17     //統計輸入的字元串中字元的個數 
18     p=chr; // p 指向字元串的第一個字元 
19     while(*p++)
20     {
21         chr_num++;
22     }
23 
24     //統計輸入的字元串中首碼 * 的個數
25     b=chr; // b 指向字元串的第一個字元 
26     while(*b++=='*')
27     {
28         b_num++;
29     }
30     
31     //刪除輸入的字元串中的首碼 *  
32     for(i=0;i<chr_num-b_num;i++)
33     {
34         chr[i]=chr[i+b_num];
35     }
36     chr[i]='\0';
37     
38     //輸出
39     cout<<"The result:"<<endl;
40     puts(chr);
41     
42     return 0; 
43 }
View Code

二、刪除尾碼 '*'

 1 #include<iostream>
 2 #include<cstdio>
 3 
 4 using namespace std;
 5 
 6 //主函數
 7 int main()
 8 {
 9     char chr[20],*t,*p; //字元串緩衝區;字元串尾指針;字元串臨時指針 
10     int chr_num=0,t_num=0; //輸入的字元串中字元的個數;輸入的字元串中尾碼 * 的個數 
11     
12     //輸入 
13     cout<<"Please input a string:"<<endl; 
14     gets(chr);
15     
16     //統計輸入的字元串中字元的個數 
17     p=chr; // p 指向字元串的第一個字元 
18     while(*p++)
19     {
20         chr_num++;
21     }    
22     
23     //統計輸入的字元串中尾碼 * 的個數 
24     t=chr+chr_num-1; // t 指向字元串的最後一個字元 
25     while(*t--=='*')
26     {
27         t_num++;
28     }
29     
30     //刪除輸入的字元串中的尾碼 *  
31     chr[chr_num-t_num]='\0';
32     
33     //輸出
34     cout<<"The result:"<<endl;
35     puts(chr);
36     
37     return 0; 
38 } 
View Code

三、刪除首碼和尾碼 '*'

 1 #include<iostream>
 2 #include<cstdio>
 3 
 4 using namespace std;
 5 
 6 //主函數
 7 int main()
 8 {
 9     char chr[20],*b,*t,*p; //字元串緩衝區;字元串頭指針;字元串尾指針;字元串臨時指針 
10     int chr_num=0,b_num=0,t_num=0; //輸入的字元串中字元的個數;輸入的字元串中首碼 * 的個數;輸入的字元串中尾碼 * 的個數 
11     int i;
12     
13     //輸入 
14     cout<<"Please input a string:"<<endl; 
15     gets(chr);
16     
17     //統計輸入的字元串中字元的個數 
18     p=chr; // p 指向字元串的第一個字元 
19     while(*p++)
20     {
21         chr_num++;
22     }
23 
24     //統計輸入的字元串中首碼 * 的個數
25     b=chr; // b 指向字元串的第一個字元 
26     while(*b++=='*')
27     {
28         b_num++;
29     }    
30     
31     //統計輸入的字元串中尾碼 * 的個數 
32     t=chr+chr_num-1; // t 指向字元串的最後一個字元 
33     while(*t--=='*')
34     {
35         t_num++;
36     }
37     
38     //刪除輸入的字元串中的首碼和尾碼 *  
39     for(i=0;i<chr_num-b_num-t_num;i++)
40     {
41         chr[i]=chr[i+b_num];
42     }
43     chr[i]='\0';
44 
45     //輸出
46     cout<<"The result:"<<endl;
47     puts(chr);
48     
49     return 0; 
50 } 
View Code

四、刪除中間 '*'

 1 #include<iostream>
 2 #include<cstdio>
 3 
 4 using namespace std;
 5 
 6 //主函數
 7 int main()
 8 {
 9     char chr[20],*b,*t,*p; //字元串緩衝區;字元串頭指針;字元串尾指針;字元串臨時指針 
10     int chr_num=0; //輸入的字元串中字元的個數;輸入的字元串中首碼 * 的個數;輸入的字元串中尾碼 * 的個數 
11     int i;
12     
13     //輸入 
14     cout<<"Please input a string:"<<endl; 
15     gets(chr);
16     
17     //統計輸入的字元串中字元的個數 
18     p=chr; // p 指向字元串的第一個字元 
19     while(*p++)
20     {
21         chr_num++;
22     }
23 
24     //令 b 指向字元串中首碼 * 之後的第一個字元 
25     b=chr; // b 指向字元串的第一個字元 
26     while(*b++=='*'); 
27 
28     //令 t 指向字元串中尾碼 * 之前的第一個字元 
29     t=chr+chr_num-1; // t 指向字元串的最後一個字元 
30     while(*t--=='*');
31     
32     //刪除字元串中間的 *  
33     p=b; //令 p 指向字元串中首碼 * 之後的第一個字元 
34     while(b<=t)
35     {
36         if(*b!='*')
37         {
38             *p=*b;
39             p++;
40             b++;
41         }
42         else
43         {
44             b++;
45         }
46     }
47     ++t; //令 t 指向字元串中尾碼 * 的第一個 * 
48     while(*t)
49     {
50         *p=*t;
51         p++;
52         t++;
53     }
54     *p='\0'; 
55     
56     //輸出
57     cout<<"The result:"<<endl;
58     puts(chr);
59     
60     return 0; 
61 } 
View Code

五、把字元串中的首碼 * 移動到字元串的末尾 

 1 #include<iostream>
 2 #include<cstdio>
 3 
 4 using namespace std;
 5 
 6 //主函數
 7 int main()
 8 {
 9     char chr[20],*b,*p; //字元串緩衝區;字元串頭指針;字元串尾指針;字元串臨時指針 
10     int chr_num=0,b_num=0; //輸入的字元串中字元的個數;輸入的字元串中首碼 * 的個數
11     int i;
12     
13     //輸入 
14     cout<<"Please input a string:"<<endl; 
15     gets(chr);
16     
17     //統計輸入的字元串中字元的個數 
18     p=chr; // p 指向字元串的第一個字元 
19     while(*p++)
20     {
21         chr_num++;
22     }
23 
24     //統計輸入的字元串中首碼 * 的個數
25     b=chr; // b 指向字元串的第一個字元 
26     while(*b++=='*')
27     {
28         b_num++;
29     }
30     
31     //把字元串中的首碼 * 移動到字元串的末尾 
32     for(i=0;i<chr_num-b_num;i++) //刪除輸入的字元串中的首碼 *  
33     {
34         chr[i]=chr[i+b_num];
35     }
36     while(i<chr_num) //在字元串的末尾添加與首碼個數相同的 * 
37     {
38         chr[i++]='*';
39     }
40     chr[i]='\0';
41     
42     //輸出
43     cout<<"The result:"<<endl;
44     puts(chr);
45     
46     return 0; 
47 } 
View Code

六、把字元串中的尾碼 * 移動到字元串的開頭 

 1 #include<iostream>
 2 #include<cstdio>
 3 
 4 using namespace std;
 5 
 6 //主函數
 7 int main()
 8 {
 9     char chr[20],*b,*t,*p; //字元串緩衝區;字元串頭指針;字元串尾指針;字元串臨時指針 
10     int chr_num=0,b_num=0,t_num=0; //輸入的字元串中字元的個數;輸入的字元串中首碼 * 的個數;輸入的字元串中尾碼 * 的個數 
11     int i;
12     
13     //輸入 
14     cout<<"Please input a string:"<<endl; 
15     gets(chr);
16     
17     //統計輸入的字元串中字元的個數 
18     p=chr; // p 指向字元串的第一個字元 
19     while(*p++)
20     {
21         chr_num++;
22     }
23 
24     //統計輸入的字元串中首碼 * 的個數
25     b=chr; // b 指向字元串的第一個字元 
26     while(*b++=='*')
27     {
28         b_num++;
29     }    
30     
31     //統計輸入的字元串中尾碼 * 的個數 
32     t=chr+chr_num-1; // t 指向字元串的最後一個字元 
33     while(*t--=='*')
34     {
35         t_num++;
36     }
37     
38     //把字元串中的尾碼 * 移動到字元串的開頭 
39     for(i=chr_num-t_num-1;i>=0;i--) //刪除輸入的字元串中的尾碼 * 
40     {
41         chr[i+t_num]=chr[i];
42     }
43     for(i=0;i<t_num;i++) //在字元串的開頭添加與尾碼個數相同的 * 
44     {
45         chr[i]='*';
46     }
47     
48     //輸出
49     cout<<"The result:"<<endl;
50     puts(chr);
51     
52     return 0; 
53 } 
View Code

七、使字元串的首碼 * 不多於 n 個

 1 #include<iostream>
 2 #include<cstdio>
 3 
 4 using namespace std;
 5 
 6 //主函數
 7 int main()
 8 {
 9     char chr[20],*b,*p; //字元串緩衝區;字元串頭指針;字元串尾指針;字元串臨時指針 
10     int chr_num=0,b_num=0; //輸入的字元串中字元的個數;輸入的字元串中首碼 * 的個數;輸入的字元串中尾碼 * 的個數 
11     int i,n=5;
12     
13     //輸入 
14     cout<<"Please input a string:"<<endl; 
15     gets(chr);
16     
17     //統計輸入的字元串中字元的個數 
18     p=chr; // p 指向字元串的第一個字元 
19     while(*p++)
20     {
21         chr_num++;
22     }
23 
24     //統計輸入的字元串中首碼 * 的個數
25     b=chr; // b 指向字元串的第一個字元 
26     while(*b++=='*')
27     {
28         b_num++;
29     }
30     
31     //使字元串的首碼 * 不多於 n 個
32     if(b_num>n)
33     {
34         //刪除輸入的字元串中的首碼和尾碼 *  
35         for(i=0;i<chr_num-b_num;i++)
36         {
37             chr[i+n]=chr[i+b_num];
38         }
39         chr[i+n]='\0';
40     }
41     
42     //輸出
43     cout<<"The result:"<<endl;
44     puts(chr);
45     
46     return 0; 
47 } 
View Code

八、使字元串的尾碼 * 不多於 n 個

 1 #include<iostream>
 2 #include<cstdio>
 3 
 4 using namespace std;
 5 
 6 //主函數
 7 int main()
 8 {
 9     char chr[20],*t,*p; //字元串緩衝區;字元串頭指針;字元串尾指針;字元串臨時指針 
10     int chr_num=0,t_num=0; //輸入的字元串中字元的個數;輸入的字元串中首碼 * 的個數;輸入的字元串中尾碼 * 的個數 
11     int i,n=5;
12     
13     //輸入 
14     cout<<"Please input a string:"<<endl; 
15     gets(chr);
16     
17     //統計輸入的字元串中字元的個數 
18     p=chr; // p 指向字元串的第一個字元 
19     while(*p++)
20     {
21         chr_num++;
22     }
23     
24     //統計輸入的字元串中尾碼 * 的個數 
25     t=chr+chr_num-1; // t 指向字元串的最後一個字元 
26     while(*t--=='*')
27     {
28         t_num++;
29     }
30     
31     //使字元串的尾碼 * 不多於 n 個
32     if(t_num>n)
33     {
34         chr[chr_num-t_num+n]='\0';
35     }
36 
37     //輸出
38     cout<<"The result:"<<endl;
39     puts(chr);
40     
41     return 0; 
42 } 
View Code
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Razor語法是在MVC3.0引入的全新的c#語法,取而代之<%...%>語法.用在mvc的view頁面. 首先談一下razor語法的基本用法: 1.如果在頁面輸出單一變數時,只要在c#語句之前加上@符號即可,範例如下: <p> 現在時刻:@DateTime.Now </p> 2、在頁面中輸出一段含 ...
  • 前言 ActionLink用於生成超鏈接,方法用於指向Controller的Action。 擴展方法與參數說明 ActionLink擴展方法如下: 參數類型說明如下: 重載格式 重載方法一: ActionLink(this HtmlHelper htmlHelper, string linkText ...
  • 這裡體現出閉包的數據共用 這裡體現出閉包的局部變數升級為成員變數 (在拉姆達表達式生成的匿名類中不會不會隨著方法執行完後彈棧 而是隨著回調函數徹底執行完後才被回收) ...
  • 一、前言 之前半年時間感覺自己有點浮躁,導致停頓了半年多的時間沒有更新博客,今天重新開始記錄博文,希望自己可以找回初心,繼續沉澱。由於最近做的項目中用到SignalR技術,所以打算總結下Asp.net SignalR的相關內容,希望對剛接觸或者接觸不多的朋友有所幫助。今天的專題就是讓大家可以快速的上 ...
  • 今天有意的在博客園裡面搜索了一下 Z.ExtensionMethods 這個擴展類庫,確發現只搜到跟這個真正相關的才兩篇博文而已,我都點進去看了一下,也都只是提到而已,沒有專門介紹,才引起我寫這篇文檔。 一. Z.ExtensionMethods 介紹 Z.ExtensionMethods 是國外( ...
  • ...
  • 2016-04-03 實現對二維數組排序❖ 對購物車商品表格實現:按數量,按單價分別降序/升序排序。❖ 查閱參考手中, usort( )函數的說明。 要求效果圖如下: 註:此處下方實際應有四個按鈕,分別控制四種不同的排序,因為一些特殊的原因無法給出。 實現代碼如下: sort-cart.php: 這 ...
  • 環境:windows 7 64位;python2.7;IDE pycharm2016.1 功能: 批量下載百度貼吧某吧某頁的所有帖子中的所有圖片 使用方法: 1.安裝python2.7,安裝re模塊,安裝urllib2模塊 2.複製以下源代碼保存為tbImgiDownloader.py文件 3.打開 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...