当前位置:网站首页>[C language] [sword finger offer article] - replace spaces
[C language] [sword finger offer article] - replace spaces
2022-07-02 21:24:00 【:-D!! yzq】
Title Description
Please implement a function , Put the string s Replace each space in with "%20".
source : Power button (LeetCode)
link :https://leetcode-cn.com/problems/ti-huan-kong-ge-lcof/
Copyright belongs to the network . For commercial reprint, please contact the official authority , Non-commercial reprint please indicate the source .
ideas
Using the double pointer idea , The first pointer traverses the array to find each space , And replace the space with ’\0’ , The second pointer points to the first address of the source string , And then use it strcat Move the address indicated by the second pointer to the first ’\0’ The string of is appended to the destination address , Last , The second pointer moves to the next address of the first pointer , loop , Until the source string is traversed .( The idea was inspired by the solution of a big man : The most coquettish I'm here , are you ready )
Code implementation
char* replaceSpace(char* s){
char *restr = NULL;
char *str = "%20";
int i = 0;
char *ptr = s;
int len = 0;
len = strlen(s);
restr = malloc(sizeof(char)*len*3+1);
if(restr == NULL)
{
printf("malloc failed!\n");
return NULL;
}
restr[0] = '\0';
for(i = 0; s[i] != '\0'; i++)
{
if(s[i] != ' ')
{
continue;
}
s[i] = '\0';
strcat(restr,ptr);
strcat(restr,str);
ptr = s + i + 1;
}
strcat(restr,ptr);
return restr;
}
When malloc And strcat When used in combination , One thing to note :malloc The allocated memory will be automatically added to the end address \0,strcat Will appear first from the address \0 Start adding , So the sentence restr[0] = '\0'; Is the essence of the whole algorithm . At that time, there were always cross-border operations , Also depressed for a long time .
边栏推荐
- Construction and maintenance of business website [1]
- 1007 maximum subsequence sum (25 points) "PTA class a exercise"
- Analyze comp-206 advanced UNIX utils
- Construction and maintenance of business websites [6]
- Spend more time with your computer on this special holiday, HHH
- Get weekday / day of week for datetime column of dataframe - get weekday / day of week for datetime column of dataframe
- 想问问,现在开户有优惠吗?在线开户是安全么?
- MySQL learning notes (Advanced)
- Common authority query instructions in Oracle
- Happy Lantern Festival! Tengyuanhu made you a bowl of hot dumplings!
猜你喜欢

Hot backup routing protocol (HSRP)

Check the confession items of 6 yyds

Customized Huawei hg8546m restores Huawei's original interface
![[shutter] the shutter plug-in is used in the shutter project (shutter plug-in management platform | search shutter plug-in | install shutter plug-in | use shutter plug-in)](/img/80/215499c66243d5a4453d8e6206c012.jpg)
[shutter] the shutter plug-in is used in the shutter project (shutter plug-in management platform | search shutter plug-in | install shutter plug-in | use shutter plug-in)
![[shutter] statefulwidget component (bottom navigation bar component | bottomnavigationbar component | bottomnavigationbaritem component | tab switching)](/img/a7/0b87fa45ef2edd6fac519b40adbeae.gif)
[shutter] statefulwidget component (bottom navigation bar component | bottomnavigationbar component | bottomnavigationbaritem component | tab switching)

Talk about macromolecule coding theory and Lao Wang's fallacy from the perspective of evolution theory

Unexpectedly, there are such sand sculpture code comments! I laughed

Web3js method to obtain account information and balance

JDBC | Chapter 4: transaction commit and rollback
![[question brushing diary] classic questions of dynamic planning](/img/31/fcd8230f809d6178f11e7095c1ef94.jpg)
[question brushing diary] classic questions of dynamic planning
随机推荐
Research Report on the overall scale, major manufacturers, major regions, products and applications of battery control units in the global market in 2022
What is the difference between programming in real work and that in school?
An analysis of the past and present life of the meta universe
Welfare, let me introduce you to someone
How to open an account online? Is it safe to open a mobile account?
2021 software security report: open source code, happiness and disaster depend on each other?
Construction and maintenance of business websites [7]
Hot backup routing protocol (HSRP)
Construction and maintenance of business websites [4]
6 pyspark Library
Record the problems encountered by nodejs asynchronism
Add two numbers of leetcode
在券商账户上买基金安全吗?哪里可以买基金
Cloud computing technology [1]
[shutter] statefulwidget component (create statefulwidget component | materialapp component | scaffold component)
股票开户要找谁?手机开户是安全么?
Research Report on market supply and demand and strategy of microplate instrument industry in China
1005 spell it right (20 points) "PTA class a exercise"
AES encryption CBC mode pkcs7padding filling Base64 encoding key 32byte iv16byte
China Indonesia advanced wound care market trend report, technological innovation and market forecast