完整题目:从键盘输入一个字符如(“12345”只有0-9)用递归算法将字符串转换为数字,求算法复杂性,并验证排序正确性
2条回答 默认 最新
- abcd_123457 2016-01-11 09:31关注
不好意思,之前发的那个没验证发现有点问题,误导了,这个验证了一下没问题。你的题目总没有说明翻译成几进制,所以我就按原样翻译了
例如字符"1234",翻译为数字1234.void GetNumFromString(char *c,unsigned long *num); void _tmain(int argc, _TCHAR* argv[]) { unsigned long x; char *pp = "1234"; x = 0; GetNumFromString(pp,(unsigned long *)&x); pp = "8234"; x = 0; GetNumFromString(pp,(unsigned long *)&x); while(1) { } } void GetNumFromString(char *c,unsigned long *num) { if(*c != '\0') { *num *= 10; if(*c >= '0' && *c <= '9') *num += *c - '0'; GetNumFromString(++c,num); } }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 ubuntu子系统密码忘记
- ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
- ¥15 保护模式-系统加载-段寄存器
- ¥15 电脑桌面设定一个区域禁止鼠标操作