如何在 C++ 中把十进制转换为二进制
本文将介绍几种在 C++ 中如何将十进制数转换为二进制表示的方法。
在 C++ 中使用自定义定义的函数将十进制数转换为二进制数
灵活的方法定义了一个函数,该函数接收 int
值,将其转换为相应的二进制表示,并将其作为一个字符串值返回。在这种情况下,我们使用%
取余运算符和 while
循环来实现该算法,其中我们每次迭代都将整数的值减少一半。
#include <iostream>
using std::cout;
using std::endl;
using std::string;
string toBinary(int n) {
string r;
while (n != 0) {
r += (n % 2 == 0 ? "0" : "1");
n /= 2;
}
return r;
}
int main() {
int number = 15;
cout << "decimal: " << number << endl;
cout << "binary : " << toBinary(number) << endl;
return EXIT_SUCCESS;
}
输出:
decimal: 15
binary : 1111
使用 std::bitset
类在 C++ 中把十进制数转换为二进制数
另外,我们也可以直接使用 STL 库中的 bitset
类。bitset
表示一个固定大小的 N 位序列,它提供了多种内置方法来有效地操作二进制数据。下面的例子显示了通过传递 string
值和 int
值来构建 bitset
对象。
#include <bitset>
#include <iostream>
using std::bitset;
using std::cout;
using std::endl;
using std::string;
string toBinary(int n) {
string r;
while (n != 0) {
r += (n % 2 == 0 ? "0" : "1");
n /= 2;
}
return r;
}
int main() {
int number = 15;
bitset<32> bs1(toBinary(number));
cout << "binary: " << bs1 << endl;
bitset<32> bs2(number);
cout << "binary: " << bs2 << endl;
return EXIT_SUCCESS;
}
输出:
binary: 00000000000000000000000000001111
binary: 00000000000000000000000000001111
请注意,在前面的代码中,我们在 bitset
声明中指定了 32 位的分配。大家可以指定不同的位数,以更好地满足自己的需求。下面的代码段中演示了多种方案。
#include <bitset>
#include <iostream>
using std::bitset;
using std::cout;
using std::endl;
using std::string;
int main() {
int number = 15;
bitset<32> bs1(number);
cout << "binary: " << bs1 << endl;
bitset<16> bs2(number);
cout << "binary: " << bs2 << endl;
bitset<8> bs3(number);
cout << "binary: " << bs3 << endl;
bitset<5> bs4(number);
cout << "binary: " << bs4 << endl;
cout << endl;
return EXIT_SUCCESS;
}
输出:
binary: 00000000000000000000000000001111
binary: 0000000000001111
binary: 00001111
binary: 01111
bitset
类有几个有用的方法对其内容进行操作。这些方法可以用来反转集合的所有位(flip
函数)或 reset
/set
序列中指定的位。还支持核心的二进制运算,如 AND
、OR
、XOR
、NOT
和 SHIFT
。我们在下面的例子中展示了其中的几个,但你可以看到 bitset
类的完整手册这里。
#include <bitset>
#include <iostream>
using std::bitset;
using std::cout;
using std::endl;
using std::string;
int main() {
int number = 15;
bitset<32> bs(number);
cout << "binary : " << bs << endl;
cout << "flipped: " << bs.flip() << endl;
cout << "shift>4: " << (bs >>= 6) << endl;
cout << "shift<5: " << (bs << 2) << endl;
cout << "reset : " << bs.reset() << endl;
cout << "set : " << bs.set(16) << endl;
return EXIT_SUCCESS;
}
输出:
binary : 00000000000000000000000000001111
flipped: 11111111111111111111111111110000
shift>4: 00000011111111111111111111111111
shift<5: 00001111111111111111111111111100
reset : 00000000000000000000000000000000
set : 00000000000000010000000000000000
相关文章
如何在 C++ 中实现毫秒级的睡眠
发布时间:2024/01/02 浏览次数:124 分类:C++
-
本文介绍了在 C++ 中使用不同方法暂停程序执行,实现睡眠的方法。本文介绍了在 C++ 中睡眠毫秒的方法。使用 std::this_thread::sleep_for 方法在 C++ 中睡眠
如何在 C++ 中将双精度数四舍五入到整数上
发布时间:2024/01/02 浏览次数:88 分类:C++
-
本文演示了如何在 C++ 中把双精度数四舍五入到整数中。本文将为大家讲解几种在 C++ 中如何将双精度数四舍五入为整数的方法。使用 round() 函数将双精度数四舍五入到整数
如何在 C++ 中以毫秒为单位获取时间
发布时间:2024/01/02 浏览次数:60 分类:C++
-
本文介绍了如何在 C++ 中获取以毫秒为单位的时间。本文将介绍多种 C++ 方法,介绍如何以毫秒为单位获取时间。
如何在 C++ 中把 Char 数组转换为 Int
发布时间:2024/01/02 浏览次数:90 分类:C++
-
本文演示了在 C++ 中把 char 数组转换为 int 类型的方法。本文将介绍将 char 数组转换为 int 类型的 C++ 方法。使用 std::strtol 函数将 char 数组转换为 int 类型
如何在 C++ 中将 ASCII 码转换为字符
发布时间:2024/01/02 浏览次数:183 分类:C++
-
本文介绍了在 C++ 中如何将 ASCII 值转换为 char 的方法。本文将演示关于如何在 C++ 中把 ASCII 值转换为字符的多种方法。在 C++ 中使用赋值运算符将 ASCII 值转换为字符
在 C++ 中以右对齐输出
发布时间:2024/01/02 浏览次数:148 分类:C++
-
本文介绍了如何在 C++ 中对输出进行右对齐的方法。本文将演示关于如何在 C++ 中对输出流进行右对齐的多种方法。使用 std::right 和 std::setw 在 C++ 中对输出进行右对齐
在 C++ 中查找字符串中的第一个重复字符
发布时间:2023/09/04 浏览次数:234 分类:C++
-
在本文中,您将学习如何在 C++ 中查找字符串中的第一个重复字符。 您将学习实现此目的的三种方法:散列技术、暴力方法和算法的编写。在 C++ 中查找字符串中的第一个重复字符
求 C++ 中的最长公共子串
发布时间:2023/09/04 浏览次数:163 分类:C++
-
在本文中,我们将讨论最长公共子串问题及其在 C++ 中使用动态规划的解决方案。最长公共子串 最长公共子串(LCS)是计算机科学中的一个众所周知的问题。
C++ 中字符串的第一个字母大写
发布时间:2023/09/04 浏览次数:125 分类:C++
-
本文将介绍将字符串的第一个字母转换为大写的各种方法。C++ 中字符串的第一个字母大写 我们将分三种不同的情况来处理这个问题: