华为的一道很简单的笔试题,当时答得很烂,现在拿出来重新搞了一下

//代码有参考<a target=_blank href="http://codepad.org/6Fd8V6z0">http://codepad.org/6Fd8V6z0</a>
#define _CRT_SECURE_NO_WARNIGNS//程序看起来有点复杂是因为考虑到字母数大于9个的时候,需要转换一下存进字符串,最后的字符串保存在了一个字符数组内了
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int number_to_char(int number, char *char_new)//将int型转换成字符型存进字符数组
{
	int ret = 0;
	if (char_new == NULL)
	{
		return -1;
	}
	int bit = 1;
	int tmp = number;
	int i = 0;
	while (tmp /= 10)
	{
		bit++;
	}
	for (i = bit - 1; i >= 0; i--)
	{
		char_new[i] = (number % 10)+48;
		number /= 10;
	}
	return ret;

}
int del_other_char(char *str_old, char *str_new)//删除除了字母以外的任何字符
{
	int ret = 0;
	if (str_old == NULL || str_new == NULL)
	{
		return -1;
	}
	while (*str_old != '\0')//去除除了小写字母以外的任何字符,拷贝到新的字符串中
	{
		if (*str_old >= 'a' && *str_old <= 'z')
		{
			*str_new++ = *str_old;
		}
		str_old++;
	}
	*str_new = '\0';
	return ret;
}
int change_str(char *str_old, char *str_new)
{
	int ret = 0;
	if (str_old == NULL || str_new == NULL)
	{
		return -1;
	}
	int str[128] = { 0 };//不会超出字母对应的ASCII码
	while (*str_old != '\0')
	{
		str[(int)*str_old++]++;
		if (*str_old != *(str_old - 1))//如果到了不相同的交界处
		{
			int i = 0;
			char number[20] = { 0 };
			ret = number_to_char(str[(int)*(str_old - 1)], number);
			if (ret != 0)
			{
				printf("ERROR!!! func number_to_char()");
				return ret;
			}
			*str_new++ = *(str_old - 1);
			//*str_new++ = str[(int)*(str_old - 1)]+48;//只能打印小于10的数字
			for (i = 0; number[i] != '\0'; i++)//将转换的字符存入字符串
			{
				*str_new++ = number[i];
			}
			str[(int)*(str_old - 1)] = 0;//记录一次之后要清零,防止下此再出现该字母次数会叠加
		}
	}
	*str_new = '\0';
	return ret;
}
int main()
{
	int ret = 0;
	char *str_old = "23423aaaaaaaaaaaaabbbbbdddddawewewew323eeee eee2323tyuttt";
	char str_new1[100];
	char str_new2[100];
	ret = del_other_char(str_old, str_new1);
	if (ret != 0)
	{
		printf("ERROR!!! func del_other_char()");
		return ret;
	}
	ret = change_str(str_new1, str_new2);
	if (ret != 0)
	{
		printf("ERROR!!! func change_str()");
		return ret;
	}
	printf("%s", str_new2);
	system("pause");
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值