面试中常见的C语言字符串操作,快来看看,是否对你有帮助!
字符串倒序输出
实现逻辑,通过strlen获取字符串长度,然后通过 len/2 进行交叉赋值,这里需要注意,不需要考虑len是奇数还是偶数的问题。
如果len是奇数,最后一个字符就不需要倒序,如果是偶数,最后两个字符就倒序。
#include “stdio.h”
void rechange_str(char *str)
{
int i, len;
char tmp;
if (NULL == str) {
return ;
}
len = strlen(str);
for (i = 0; i < len/2; i ++) {
tmp = str[i];
str[i] = str[len-i-1];
str[len-i-1] = tmp;
}
}
int main(void)
{
char str[20] = “hello,world”;
printf(“%sn”,str);
rechange_str(str);
printf(“%sn”,str);
return (0);
}
程序输出
hello,world
dlrow,olleh
——————————–
Process exited after 0.02841 seconds with return value 0
请按任意键继续. . .
整型转字符串
实现逻辑,每个整数看其转换进制,从个位到十位百位都可以通过%操作加上/操作获得,再用一个字符数组保存0-F。
用个位数对应值转为字符,注意转换出的字符串是反向的,还要考虑传入的若是负数如何处理,再用翻转字符串完成最后整个操作。
下面这段代码需要好好研究一下,最好自己运行试试。
#include “stdio.h”
char *sky_itoa(int value, char *str, unsigned int radix)
{
char list[] = “0123456789ABCDEF”;
unsigned int tmp_value;
int i, j, k;
if (NULL == str) {
return NULL;
}
if (2 != radix && 8 != radix && 10 != radix && 16 != radix) {
return NULL;
}
i = 0;
k = 0;
if (radix == 10 && value < 0) {
tmp_value = (unsigned int)(0 – value);
str[i++] = ‘-‘;
k = 1;
} else {
tmp_value = (unsigned int)value;
}
do {
str[i++] = list[tmp_value%radix];
tmp_value /= radix;
} while(tmp_value);
str[i] = ‘