C: 将字符串中的大数字转换为整数模n
C: Convert big number from string to int modulo n
我正在尝试将实数(>100位)从字符串转换为Zn加法组(模n)中的整数。n保证在标准的Cint范围内(比如n=12345)。
无论是atoi然后"%"的简单方法,还是BigIntiger在这里都不起作用。
有什么想法可以实施吗?
我假设你在问题中指的是C++(没有C/C++这回事)。atoi将字符串转换为一个可以放入标准整数(32位)的数字,所以这不是您想要的。您必须编写自己的转换函数。
为了保持数学简单,让我们假设你的数字是正的。首先要注意,有模的加法和乘法等价于没有模的加法。所以我们只需要保留这两个运算的结果,模n。然后注意,我们可以逐位构造大数字:
unsigned int convert(const char* s, int n) {
long long x = 0;
for (char *p = s; *p; p++) {
x *= 10;
x += (int)(*p - '0');
x %= n;
}
return x;
}
为了清楚起见,我省略了任何错误检查。作为练习,编写一些额外的代码以确保s是一个有效的以null结尾的字符串,表示一个没有任何空格/额外格式的大整数。
相关文章:
- 努力将整数转换为链表。不知道我在这里做错了什么
- 将"打开的CV图像"中的"颜色"转换为整数格式
- 如何在C++中将整数转换为其数字数组
- 尝试将字符串/字符转换为整数会产生意外结果
- 如何使用C++将字符串中的字符转换为整数变量
- 如何将整数字符串转换为整数的二维向量?
- 如果整数与指针大小相同,则重新解释将整数转换为指针双射是否具有双射作用?
- 使用 "stringstream " 将字符串转换为整数
- 将字符串转换为浮点数或整数,而无需使用内置函数(如 atoi 或 atof)
- 如何检测 std::vector::emplace_back 上的隐式转换损失整数精度
- 如何防止双精度值到整数的隐式转换
- 为什么此指针值不能转换为整数的规则是什么?
- 如何解决隐式转换丢失整数精度:'size_t'(又名"无符号长")到'int'警告?
- 在 C++ 中将整数数组转换为位集表示形式的最佳方法?
- 为什么在将 void 指针转换为整数指针时出现分段错误
- 将字符串(可以是十进制字符串或十六进制字符串)转换为整数C++
- 整数类型应该显式转换(例如"int"到"无符号")还是只会增加混乱?
- 如何使用 STL 算法将整数向量转换为字符串向量?
- 无法将"整数 (*)[m]"转换为"整数 (*)[100000]
- 静态强制转换允许转换对象指针,但不允许转换整数