E-Dreamer

脚踏实地,仰望星空

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

PS: 程序为cpp代码,最重要理解操作。

方法一: n进制方法,也可以解决转换为其他进制问题。

/*将整数转化为二进制的string 输出*/
string convert(int num) {
	string res = "";
	if (num == 0) return "0";
	int val = num;
	num = abs(num);
	while (num) {
		res.insert(0, to_string(num % 2));
		num /= 2;
	}
	if (val < 0) res.insert(0, "-");
	return res;
} 

方法二: 使用容器转换

/*使用vector进行存储*/
vector<int> convert(int n) {
	int temp;
	temp = n;
	vector<int>  res;
	while (temp !=0) {
		res.push_back(temp % 2);
		temp = temp >> 1;
	}
       return  res;
}    

方法三: 递归输出转换二进制

/*递归转换二进制*/
void convert(int n) {
	int a;
	a = n % 2;
	n = n >> 1;
	if (n == 0)
		return;
	else
		convert(n);
	cout << a;  // 01逐个输出
}

  

方法四:位运算转换二进制

/*位运算转换二进制*/
void convert(int n) {
	for (int = 31; i >= 0; i--) {  // 32位,逐步与1做与运算
		cout << (n >> i) & 1;
	}
}

方法五:使用bitset 转换二进制

void convert(int n) {
	cout << bitset<sizeof(int) * 8>(n) << endl;
}

  

posted on 2020-01-12 20:51  E-Dreamer  阅读(1754)  评论(0编辑  收藏  举报