字符串的分割
程序员文章站
2022-04-30 18:28:59
...
今天偷偷偷偷偷偷做课程水题遇到的一个字符串分割的题(poj)
排序
Description
输入一行数字,如果我们把这行数字中的‘5’都看成空格,那么就得到一行用空格分割的若干非负整数(可能有些整数以‘0’开头,这些头部的‘0’应该被忽略掉,除非这个整数就是由若干个‘0’组成的,这时这个整数就是0)。
你的任务是:对这些分割得到的整数,依从小到大的顺序排序输出。
Input
输入包含多组测试用例,每组输入数据只有一行数字(数字之间没有空格),这行数字的长度不大于1000。
输入数据保证:分割得到的非负整数不会大于100000000;输入数据不可能全由‘5’组成。
Output
对于每个测试用例,输出分割得到的整数排序的结果,相邻的两个整数之间用一个空格分开,每组输出占一行。
Sample Input
0051231232050775
Sample Output
0 77 12312320
Source
POJ
使用该函数:
#include<stdio.h>
#include<string.h>
int main(void)
{
char buf[]="aaa@qq.com@aaa@qq.com@heima";
char*temp = strtok(buf,"@");
while(temp)
{
printf("%s ",temp);
temp = strtok(NULL,"@");
}
return0;
}
该函数的手工实现转自https://www.cnblogs.com/Bob-tong/p/6610806.html
#include<stdio.h>
#include<string.h>
//根据函数原型实现strtok()函数
char* myStrtok_origin(char* str_arr,constchar* delimiters,char**temp_str)
{
//定义一个指针来指向待分解串
char*b_temp;
/*
* 1、判断参数str_arr是否为空,如果是NULL就以传递进来的temp_str作为起始位置;
* 若不是NULL,则以str为起始位置开始切分。
*/
if(str_arr == NULL)
{
str_arr =*temp_str;
}
//2、跳过待分解字符串
//扫描delimiters字符开始的所有分解符
str_arr += strspn(str_arr, delimiters);
//3、判断当前待分解的位置是否为'\0',若是则返回NULL,否则继续
if(*str_arr =='\0')
{
return NULL;
}
/*
* 4、保存当前的待分解串的指针b_temp,调用strpbrk()在b_temp中找分解符,
* 如果找不到,则将temp_str赋值为待分解字符串末尾部'\0'的位置,
* b_temp没有发生变化;若找到则将分解符所在位置赋值为'\0',
* b_temp相当于被截断了,temp_str指向分解符的下一位置。
*/
b_temp = str_arr;
str_arr = strpbrk(str_arr, delimiters);
if(str_arr == NULL)
{
*temp_str = strchr(b_temp,'\0');
}
else
{
*str_arr ='\0';
*temp_str = str_arr +1;
}
//5、函数最后部分无论找没找到分解符,都将b_temp返回。
return b_temp;
}
//使用myStrtok来简化myStrtok_origin函数
char* myStrtok(char* str_arr,constchar* delimiters)
{
staticchar*last;
return myStrtok_origin(str_arr, delimiters,&last);
}
int main(void)
{
char buf[]="aaa@qq.com@aaa@qq.com@heima";
//1、使用myStrtok_origin()函数
char*temp_str = NULL;
char*str = myStrtok_origin(buf,"@",&temp_str);
while(str)
{
printf("%s ",str);
str = myStrtok_origin(NULL,"@",&temp_str);
}
//2、使用myStrtok()函数
char*str1 = myStrtok(buf,"@");
while(str1)
{
printf("%s ",str1);
str1 = myStrtok(NULL,"@");
}
return0;
}
推荐阅读
-
ThinkPHP自动填充实现无限级分类的方法,thinkphp填充_PHP教程
-
php ci框架中加载css和js文件失败的解决方法_PHP
-
死磕,Java注解(Annotation )的秒懂之道
-
写项目一定会遇到的插件
-
有关JavaScript中浅拷贝、深拷贝的简单研究
-
php通过array_merge()函数合并关联和非关联数组的方法,array_merge数组
-
Win11没有杜比视界音效该怎么办? Win11杜比视界音效的开启方法
-
如何写JS数组sort的比较函数_javascript技巧
-
Win11杜比全景声怎么下载安装? Win11杜比全景声的安装使用教程
-
PHP中is_file不能替代file_exists的理由_PHP