字符串转为整数求指点

题目描述:输入一个表示整数的字符串,把该字符串转换成整数并输出,例如输入字符串"345",则输出整数345。 请完成函数StrToInt,实现字符串转换成整数的功能。 友情提醒: 提交代码之前,请复查下你的程序,比如当给的字符串是如左边图片所示的时候,有考虑到么? 当然,它们各自对应的正确输出如右边图片所示(假定你是在32位系统下,编译环境是VS2008以上) input:                                          output:                            注:以上只是部分测试数据,不代表上述数据通过了,即挑战成功。
挑战规则:
完成功能函数StrToInt即可,但不要去改动函数名,参数,至于main函数是为方便你在提交代码之前进行在线编译测试; 不得用库函数atoi。                           


这题需要考虑的细节很多,不过经过多次提交后得到代码如下,不知是否可通过。

求指点:

int StrToInt(const char* str)
{
	int fuhaogeshu = 0, ffzfgs = 0;
	int i,fuhao=1,tjjh=0;
	int len = strlen(str);
	int r=0,p=0;
	while ( --len >= 0 && str[len] == 32){}
	for ( i = 0; i <= len && str[i]!=0; i++)
	{
		if (str[i]!=32)
		{
			if (fuhao == 1 && str[i] == '-' && tjjh==0)
			{
				if (p==2)
				{
					break;
				}
				p = 1;
				fuhao = -1;
			}
			else if (str[i]>='0' && str[i]<='9')
			{
				r = r * 10 + str[i] - '0';
				p = 2;
			}
			else if (str[i] == '+' && p == 0 && tjjh==0)
			{
				tjjh++;
			}
			else
			{
				break;
			}
		}
		else
		{
			if (p>0 || tjjh>0)
			{
				break;
			}
		}
	}
	return r*fuhao;
}

 

### SQL中将字符串数据换为整数类型的方法 在SQL中,可以使用 `CONVERT` 或 `CAST` 函数将字符串类型的值换为整数类型。以下是详细的说明和示例代码。 #### 使用 `CONVERT` 函数 `CONVERT` 函数允许将一个数据类型的值显式换为另一个数据类型。其语法如下: ```sql CONVERT(target_data_type, expression, style) ``` 其中,`target_data_type` 是目标数据类型(如 `INT`),`expression` 是要换的值或列,`style` 是可选参数,用于指定日期或时间格式的样式[^5]。 以下是一个将字符串换为整数的示例: ```sql SELECT CONVERT(INT, '123') AS ConvertedInteger; ``` #### 使用 `CAST` 函数 `CAST` 函数是另一种将数据类型换为另一种数据类型的方法。其语法较为简单: ```sql CAST(expression AS target_data_type) ``` 下面是一个使用 `CAST` 将字符串换为整数的示例: ```sql SELECT CAST('456' AS INT) AS ConvertedInteger; ``` 需要注意的是,如果字符串包含非数字字符,则会引发错误。例如,尝试将 `'abc'` 换为整数会导致换失败并抛出异常。 #### 示例:处理无效字符串 为了确保安全性,在实际应用中可以结合 `ISNUMERIC` 函数来验证字符串是否可以安全地换为整数。以下是一个示例: ```sql SELECT CASE WHEN ISNUMERIC('123') = 1 THEN CAST('123' AS INT) ELSE NULL END AS SafeConversion; ``` #### 处理带符号的字符串 对于带有正负号的字符串,SQL Server 的 `CONVERT` 和 `CAST` 函数同样能够正确处理。例如: ```sql SELECT CONVERT(INT, '-789') AS NegativeInteger; ``` ```sql SELECT CAST('+101' AS INT) AS PositiveInteger; ``` 以上代码均能成功执行,并返回正确的整数值。 #### 注意事项 - 确保输入字符串仅包含有效的数字字符。否则,换操作将失败并抛出错误。 - 如果需要处理更复杂的字符串整数换逻辑,可能需要自定义函数或使用编程语言中的高级解析方法[^4]。 ### 示例代码总结 以下是使用 `CONVERT` 和 `CAST` 函数进行字符串整数换的完整示例: ```sql -- 使用 CONVERT 函数 SELECT CONVERT(INT, '123') AS ConvertedInteger; -- 使用 CAST 函数 SELECT CAST('456' AS INT) AS ConvertedInteger; -- 安全换示例 SELECT CASE WHEN ISNUMERIC('123') = 1 THEN CAST('123' AS INT) ELSE NULL END AS SafeConversion; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值