[问题解决]:string转无符号数

两种方法

1、stoul()函数

#include <string>
unsigned long stoul ( const std::string& str, std::size_t* pos = nullptr, int base = 10 );

功能:将字符串转换为无符号整数。解析 str ,将其内容解释为指定基数的整数,该基数作为无符号长整型值返回。
参数:
str:要转换的字符串
pos:整数的地址,用于存储处理的字符数
base:数字基数,默认为十进制

string str;
unsigned char num = static_cast<unsigned char>(std::stoul(str));

2、 stringstream

#include <sstream>
#include <string>
string str;
unsigned char num;
unsigned short num_s
std::stringstream(str)>>num_s;
num= static_cast<unsigned char>(num_s);

这个方法,string直接转为unsigned char会被截断,只剩最高位。
可以从string转为unsigned short再转为unsigned char

https://www.zhihu.com/question/643004108
https://en.cppreference.com/w/cpp/string/basic_string/stoul
https://blog.csdn.net/d704791892/article/details/129713975
https://blog.csdn.net/weixin_43899069/article/details/110290292
https://blog.csdn.net/liu_feng_zi_/article/details/108028930
https://blog.csdn.net/qq_44378854/article/details/114376301

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是 C 语言的实现代码: ```c #include <stdio.h> #include <string.h> #define MAXN 1000 struct bign { int d[MAXN], len; bign() // 结构体初始化 { memset(d, 0, sizeof(d)); len = 0; } }; bign change(char str[]) // 将字符串换为 bign 结构体 { bign a; a.len = strlen(str); for (int i = 0; i < a.len; i++) a.d[i] = str[a.len - 1 - i] - '0'; return a; } int compare(bign a, bign b) // 比较两个大的大小,a > b 返回 1,a = b 返回 0,a < b 返回 -1 { if (a.len > b.len) return 1; else if (a.len < b.len) return -1; else { for (int i = a.len - 1; i >= 0; i--) { if (a.d[i] > b.d[i]) return 1; else if (a.d[i] < b.d[i]) return -1; } return 0; } } bign add(bign a, bign b) // 无符号加法 { bign c; int carry = 0; // 进位初始化为 0 for (int i = 0; i < a.len || i < b.len; i++) { int tmp = a.d[i] + b.d[i] + carry; // 当前位的值等于两个当前位的和加上上一位的进位 c.d[c.len++] = tmp % 10; // 当前位的值等于 tmp 模 10 的余 carry = tmp / 10; // 计算进位 } if (carry != 0) // 如果最高位有进位,将进位加到最高位上 c.d[c.len++] = carry; return c; } bign sub(bign a, bign b) // 无符号减法 { bign c; for (int i = 0; i < a.len || i < b.len; i++) { if (a.d[i] < b.d[i]) // 如果 a 的当前位小于 b 的当前位,借位 { a.d[i] += 10; // 当前位加上 10 a.d[i + 1]--; // 下一位减 1 } c.d[c.len++] = a.d[i] - b.d[i]; // 计算当前位的差 } while (c.len > 1 && c.d[c.len - 1] == 0) // 去除高位的 0 c.len--; return c; } void print(bign a) // 输出 bign 结构体 { for (int i = a.len - 1; i >= 0; i--) printf("%d", a.d[i]); printf("\n"); } int main() { char str1[MAXN], str2[MAXN]; scanf("%s%s", str1, str2); bign a = change(str1), b = change(str2); bign c = add(a, b), d = sub(a, b); print(c); print(d); return 0; } ``` 思路如下: 首先,我们定义一个结构体 `struct bign`,用来表示无符号。结构体中包含一个整型组 `int d[MAXN]` 和一个整型变量 `int len`,分别用来存储数字的每一位和数字的长度。 接着,我们实现三个函: - `change(char str[])`:将一个字符串转换成一个 `bign` 结构体。 - `compare(bign a, bign b)`:比较两个无符号的大小,返回 1 表示第一个大于第二个,返回 0 表示两个相等,返回 -1 表示第一个小于第二个。 - `add(bign a, bign b)`:实现两个无符号的加法。 在实现减法之前,我们需要先解决一个问题:如何计算一个无符号 `a` 减去另一个无符号 `b` 的差。我们可以先将 `b` 按照加法的方式取反(即将每一位上的数字 9 减去它原来的数字),然后将取反后的 `b` 和 `a` 相加,即可得到 `a-b` 的值。 具体实现方法如下: - 先将 `a` 和 `b` 的长度都扩展到相等的长度(不足的高位用 0 补齐)。 - 从低位到高位,用 `a` 的当前位减去 `b` 的当前位,如果 `a` 的当前位小于 `b` 的当前位,将当前位向高位借位。 - 如果减完后最高位为 0,则将高位的 0 去掉。 最后,我们编写主函,读入两个字符串,将它们转换成 `bign` 结构体,然后分别调用加法和减法函,输出它们的和和差。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值