7-5 字符串转换成十进制整数 (15 分) 测试点 2 测试

这篇博客介绍了如何处理一个包含非法字符的十六进制字符串,将其转换为十进制数。作者通过三种不同的C语言实现方法展示了如何过滤非十六进制字符,并特别讨论了负数和特殊情况的处理。文章还提到了测试策略,包括符号穷举和范围二分法,用于确保代码的正确性。
摘要由CSDN通过智能技术生成

7-5 字符串转换成十进制整数 (15 分)

输入一个以#结束的字符串,本题要求滤去所有的非十六进制字符(不分大小写),组成一个新的表示十六进制数字的字符串,然后将其转换为十进制数后输出。如果在第一个十六进制字符之前存在字符“-”,则代表该数是负数。

输入格式:

输入在一行中给出一个以#结束的非空字符串。

输出格式:

在一行中输出转换后的十进制数。题目保证输出在长整型范围内。

输入样例:

+-P-xf4+-1!#

输出样例:

-3905

前提:测试点有三个 编号分别是 0 1 2 

测试点 2 的特征是    长度为 16可见字符 其中第八位是 负号 其余位置均为非法字符的字符串。就是说 整个字符串中只有负号是十六进制判断中的合法字符 ,其余的都不合法!!!!! 

模拟输入样例:!!!!!!!!-!!!!!!!#

模拟输出样例:0

 

我一共写了三种代码  第一种 不经意绕开了 正确我们来看一下第一种绕开法: (C++)

#include <bits/stdc++.h>

using nam
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值