当前位置:网站首页>C language self compiled string processing function - string segmentation, string filling, etc
C language self compiled string processing function - string segmentation, string filling, etc
2022-04-23 15:51:00 【MallocLu】
List of articles
String padding usage example
#include <stdio.h>
#include <stdlib.h>
#include "CStringTools.h"
int main()
{
char cmd[1000];
char cmdList[50][20];
while (1)
{
scanf("%s", cmd);
if (strcmp(cmd, "exit") == 0)
break;
fillWithKeys(cmd, "*#", ' ');
printf("%s\n\n", cmd);
}
return 0;
}

Example of string segmentation
#include <stdio.h>
#include <stdlib.h>
#include "CStringTools.h"
int main()
{
char cmd[1000];
char cmdList[50][20];
while (1)
{
scanf("%s", cmd);
if (strcmp(cmd, "exit") == 0)
break;
int cnt = split(cmdList, cmd, "*#");
for (int i = 0; i < cnt; ++i)
printf("%d\t\t%s\n", i+1, cmdList[i]);
printf("\n");
}
return 0;
}

Tool function code
Yes .h and .c Two documents , Add it to your project , also #include “CStringTools.h”, You can use the functions .
// CStringTools.h file
#ifndef CSTRINGTOOLS_H_INCLUDED
#define CSTRINGTOOLS_H_INCLUDED
#include <string.h>
#include <malloc.h>
// stay str Specify the characters keys Fill one before and after content
void fillWithKeys(char *str, char* keys, char content);
// The string str According to the separator keys Divided into strList( ceiling 50 A string length 20)
// Returns the number of strings actually divided into
int split(char strList[][20], char *str, char *keys);
#endif // CSTRINGTOOLS_H_INCLUDED
// CStringTools.c file
#include "CStringTools.h"
void fillWithKeys(char *str, char* keys, char content)
{
char *tmp = (char *)malloc(sizeof(char) * strlen(str));
strcpy(tmp, str);
int index = 0;
for (int i = 0; i < strlen(tmp); ++i)
{
int flag = 0;
for (int j = 0; j < strlen(keys); ++j)
{
if (keys[j] == tmp[i])
{
flag = 1;
break;
}
}
if (flag)
str[index++] = content;
str[index++] = tmp[i];
if (flag)
str[index++] = content;
}
str[index] = '\0';
free(tmp);
}
int split(char strList[][20], char *str, char *keys)
{
int cnt = 0;
str[strlen(str)] = keys[0];
str[strlen(str)] = '\0';
int start = -1;
for (int i = 0; i < strlen(str); ++i)
{
int flag = 0;
for (int j = 0; j < strlen(keys); ++j)
{
if (keys[j] == str[i])
{
flag = 1;
break;
}
}
if(flag)
{
if (i - start > 1)
{
// cutting [start+1,i-1]
for (int j = start + 1; j <= i - 1; ++j)
{
strList[cnt][j-start-1] = str[j];
}
strList[cnt][i - start - 1] = '\0';
++cnt;
}
start = i;
}
}
return cnt;
}
版权声明
本文为[MallocLu]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/04/202204231548205933.html
边栏推荐
猜你喜欢

IronPDF for .NET 2022.4.5455

大型互联网为什么禁止ip直连

Timing model: gated cyclic unit network (Gru)

Metalife established a strategic partnership with ESTV and appointed its CEO Eric Yoon as a consultant

Pgpool II 4.3 Chinese Manual - introductory tutorial

C, calculation method and source program of bell number

How can poor areas without networks have money to build networks?

Neodynamic Barcode Professional for WPF V11. 0

新动态:SmartMesh和MeshBox的合作新动向

mysql乐观锁解决并发冲突
随机推荐
C language --- string + memory function
Deletes the least frequently occurring character in the string
Go language, condition, loop, function
CAP定理
Go语言切片,范围,集合
北京某信护网蓝队面试题目
Temporal model: long-term and short-term memory network (LSTM)
Timing model: gated cyclic unit network (Gru)
vim指定行注释和解注释
Import address table analysis (calculated according to the library file name: number of imported functions, function serial number and function name)
MySQL optimistic lock to solve concurrency conflict
Basic concepts of website construction and management
Leetcode-374 guess the size of the number
utils. Deprecated in35 may be cancelled due to upgrade. What should I do
Pgpool II 4.3 Chinese Manual - introductory tutorial
一文掌握vscode远程gdb调试
多级缓存使用
[self entertainment] construction notes week 2
gps北斗高精度卫星时间同步系统应用案例
幂等性的处理