題目1510:替換空格

題目1510:替換空格

時間限制:1 秒

內存限制:128 兆

特殊判題:

提交:9360

解決:2401

題目描述:

請實現一個函數,將一個字符串中的空格替換成“%20”。例如,當字符串爲We Are Happy.則經過替換之後的字符串爲We%20Are%20Happy。

輸入:

每個輸入文件僅包含一組測試樣例。
對於每組測試案例,輸入一行代表要處理的字符串。

輸出:

對應每個測試案例,出經過處理後的字符串。

樣例輸入:
We Are Happy
樣例輸出:
We%20Are%20Happy

 


The code:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
// 04ReplaceBlank.cpp : 定義控制檯應用程序的入口點。
//
 
#include <stdio.h>
#include <iostream>
using namespace std;
 
void ReplaceBlank(char string[], int length)
{
    if(string == NULL && length <= 0)
        return;
 
    int originalLength = 0;
    int numberOfBlank = 0;
    int i = 0;
    while(string[i] != '\0')
    {
        ++ originalLength;
 
        if(string[i] == ' ')
            ++ numberOfBlank;
 
        ++ i;
    }
     
    int newLength = originalLength + numberOfBlank*2;
    if(newLength > length)
        return;
 
    int indexOfOriginal = originalLength;
    int indexOfNew = newLength;
 
    while(indexOfOriginal>=0 && indexOfNew > indexOfOriginal)
    {
        if (string[indexOfOriginal] == ' ')
        {
            string[indexOfNew--] ='0';
            string[indexOfNew--]='2';
            string[indexOfNew--]='%';
 
 
        }
        else
            string[indexOfNew--] = string[indexOfOriginal];
 
        -- indexOfOriginal;
 
 
    }
 
 
 
 
}
 
 
 
int main()
    const int length = 1000000;
    char str[length];
    gets(str);
 
    ReplaceBlank(str,length);
    cout<<str<<endl;
 
 
    return 0;
}
 
/**************************************************************
    Problem: 1510
    User: yymydm
    Language: C++
    Result: Accepted
    Time:20 ms
    Memory:2424 kb
****************************************************************/

 


error記錄:
(一)Compile Error:錯誤的以爲main函數中用到的gets函數是包含在#include<string>的;實際上是包含在#include<stdio.h>

(二)Runtime Error:一開始length=1000,結果無法通過某些測試案例:
後改爲1000000纔可。顯然是因爲給字符串數組分配1000大小無法滿足某些測試用例需要的內存。


擴展:
最初,在對main()中進行字符串輸入處理時,我簡單地以爲scanf(“%s”,str);或者 cin>>str;
可以實現,結果檢查驗證後才發現這兩中方式在遇到字符串中的空白字符時便會終止讀取。
例如輸入we are happy , 實際只是讀取到we後便終止。

故而採用了gets()實現輸入含空白字符的字符串。

gets(字符數組);puts(字符數組)

對一個字符串(以‘\0’結束的字符序列)進行輸入、輸出操作。
例如:gets(str);
在當我們在鍵盤上輸入we are happy ,按下回車鍵,實現向字符數組輸入一個字符串:we are happy及結束符‘\0’(共13個字符)。


擴展:
最初,在對main()中進行字符串輸入處理時,我簡單地以爲scanf(“%s”,str);或者 cin>>str;
可以實現,結果檢查驗證後才發現這兩中方式在遇到字符串中的空白字符時便會終止讀取。
例如輸入we are happy , 實際只是讀取到we後便終止。

故而採用了gets()實現輸入含空白字符的字符串。

gets(字符數組);puts(字符數組)

對一個字符串(以‘\0’結束的字符序列)進行輸入、輸出操作。
例如:gets(str);
在當我們在鍵盤上輸入we are happy ,按下回車鍵,實現向字符數組輸入一個字符串:we are happy及結束符‘\0’(共13個字符)。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章