編修字串 問題描述 本題目為字串處理問題,程式需讀取一行英文字串,並依據讀入相關之指令, 來編修該字串。程式開始執行時,游標位於該英文字串的第一個字元。

34 - 編修字串

問題描述
本題目為字串處理問題,程式需讀取一行英文字串,並依據讀入相關之指令,
來編修該字串。程式開始執行時,游標位於該英文字串的第一個字元。

編修字串的指令如下:
0 : 移動游標至目前所在行的第一個字元。
$ : 移動游標至字串的結束位置(即最後一個字元的下一個位置)。
x : 刪除目前游標所在位置的字元(如果在字串的結束位置則不做任何動作)。
s : 與游標所在位置的右邊字元做交換動作(如果游標在結束位置或結束位置的前一個位置,則不做任何動作)。
i : 在游標所在位置插入字元。如指令 ‘ix’ ,則是在游標目前所在位置前插入字元‘x’,游標停留在原始的位置(即所插入‘x’ 的下一位置)。
u : 如果游標所在位置之資料為英文字母,則將該字母改為大寫,並將游標往右移一個位置,如不是英文字母,則直接將游標往右移一個位置。

  • : 將游標向右移一個位置。
  • : 將游標向左移一個位置。

輸入說明:
第一行為要編修的英文字串。
第二行為編修英文字串的指令。

輸出說明:
請輸出處理完畢之字串。


範例輸入1 說明:
i have a bell
$is----x---sxs0u+++xxid

第1個指令為 $,將游標移至字串的結束位置。 ( 執行後游標位置的字元為 ‘\0’ )
第2個指令為 i,從輸入拿一字元 s,並在游標位置前插入。( 執行後游標位置的字元為 ‘\0’ )
第3個指令為 -,將游標向左移一個位置。 ( 執行後游標位置的字元為 s )
第4個指令為 -,將游標向左移一個位置。 ( 執行後游標位置的字元為 l )
第5個指令為 -,將游標向左移一個位置。 ( 執行後游標位置的字元為 l )
第6個指令為 -,將游標向左移一個位置。 ( 執行後游標位置的字元為 e )
第7個指令為 x,刪除目前游標所在位置的字元。 ( 執行後游標位置的字元為 l )
第8個指令為 -,將游標向左移一個位置。 ( 執行後游標位置的字元為 b )
第9個指令為 -,將游標向左移一個位置。 ( 執行後游標位置的字元為 空白 )
第10個指令為 -,將游標向左移一個位置。 ( 執行後游標位置的字元為 a )
第11個指令為 s,與游標所在位置的右邊字元做交換動作。 ( 執行後游標位置的字元為 空白 )
第12個指令為 x,刪除目前游標所在位置的字元。 ( 執行後游標位置的字元為 a )
第13個指令為 s,與游標所在位置的右邊字元做交換動作。 ( 執行後游標位置的字元為 b )
第14個指令為 0,將游標移至字串的開始位置。 ( 執行後游標位置的字元為 i )
第15個指令為 u,將游標所在位置的字元改為大寫。 ( 執行後游標位置的字元為 空白 )
第16個指令為 +,將游標向右移一個位置。 ( 執行後游標位置的字元為 h )
第17個指令為 +,將游標向右移一個位置。 ( 執行後游標位置的字元為 a )
第18個指令為 +,將游標向右移一個位置。 ( 執行後游標位置的字元為 v )
第19個指令為 x,刪除目前游標所在位置的字元。 ( 執行後游標位置的字元為 e )
第20個指令為 x,刪除目前游標所在位置的字元。 ( 執行後游標位置的字元為 空白 )
第21個指令為 i,從輸入拿一字元 d,並在游標位置前插入。( 執行後游標位置的字元為 空白 )

範例輸出1 說明:
I had balls


Sample Input 2:
hellol, I am a frog.
$-----xxxxipieirisioin0u++xs

Sample Output 2:
Hello, I am a person.


Sample Input 3:
Who lives in a pineapple in the sea
xxxiyioiu0u$----------xxiuinidieir$i.

Sample Output 3:
You lives in a pineapple under the sea.


Sample Input 4:
he is baosbrnet yellow and porous
xxxxxxsu+s++s++s++$i iiisi ihie

Sample Output 4:
Absorbent yellow and porous is he


Sample Input 5:
You N!a!u!t!i!c!a!l! nonsense be you wish it
+++++x+x+x+x+x+x+x+x$-----------i -ig-in-ii-ih-it-ie-im-io-is

Sample Output 5:
You Nautical nonsense be something you wish it

img

你题目的解答代码如下:

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
int main()
{
    int i,j,p=0,slen,clen;
    char str[1000],ct[1000];
    gets(str);
    gets(ct);
    slen = strlen(str);
    clen = strlen(ct);
    for (i = 0; i <clen; i++)
    {
        switch (ct[i])
        {
        case '0':
            p = 0;
            break;

        case '$':
            p = slen;
            break;

        case 'x':
            if (p>=slen) break;
            for (j = p; j < slen; j++)
                str[j] = str[j+1];
            slen--;
            break;

        case 's':
            if (p>=slen-1) break;
            char t = str[p];
            str[p] = str[p+1];
            str[p+1] = t;
            break;

        case 'i':
            if (p>slen) break;
            for (j = slen; j >= p; j--)
                str[j+1] = str[j];
            str[p] = ct[++i];
            p++;
            slen++;
            break;

        case 'u':
            if (p>=slen) break;
            if (str[p]>='a' && str[p]<='z')
               str[p] -= 32;
            p++;
            break;

        case '+':
            p++;
            break;

        case '-':
            p--;
            break;
        }
    }
    printf("%s\n", str);
    return 0;
}

如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!

img

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632