我是靠谱客的博主 单身溪流,最近开发中收集的这篇文章主要介绍笔记~ 保留位数 输出格式 进制转换 四舍五入,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

保留位数

保留位数通常在题目中以求除法再让我们保留几位小数等等
c++中用fixed 和setprecision(n)函数保留n位小数
c语言则是 printf("%.nf",变量)来解决
输出结果第一组的第一行没有小数,之后的有了因为fixed对之后一直有用

#include <iostream>
#include<math.h>
#include<iomanip>
using namespace std;
int main()
{
	double sum;
	double avg;
	while (cin >> sum)
	{
		avg = sum / 3;
		cout << "1"<<sum << endl;  
		cout << fixed << setprecision(3) <<"2"<< avg << endl;  //保留小数
		cout <<"3"<< sum / 4<<endl;    //发现fixed 以及setpre函数会对之后的所有数字都产生作用
	}
}

在这里插入图片描述

输出格式(填充输出,输出宽度等)

看代码即可,注意头文件用iomainip

#include <iostream>
#include<math.h>
#include<iomanip>
using namespace std;
int main()
{
	double sum;
	double avg;
	while (cin >> sum)
	{
		cout << "1: "<<setw(5) << sum << endl; //默认右对齐
		cout << "2: " << setw(5)<<left << sum << endl;  //左对齐 用right就是右对齐楼
		cout << "3: " << setw(5) <<setfill('*')<< sum << endl;  //左对齐依然有效
	}
}

在这里插入图片描述

进制转换

进制转换有函数比较简单先看函数的吧

#include <bitset>  
#include<iostream>
using namespace std;
int main()
{
	cout << "32的8进制:" << std::oct << 32 << endl;
	cout << "32的10进制" << std::dec << 32 << endl;
	cout << "32的16进制:" << std::hex << 32 << endl;
	cout << "32的2进制: " << bitset<4>(32) << endl;
	//     <8>:表示保留8位输出   小于8比如4则输出低四位
	return 0;
}

在这里插入图片描述

有的题目就是要求进制转换,无非就是m进制转换为n进制,通常是以十进制作为中间量,分两步解决

#include <bitset>  
#include<math.h>
#include<iostream>
using namespace std;
int transten(int m,int x) //m进制数x转化为10进制
{
	int t = 0,temp;
	int ans = 0;
	while (x)
	{
		ans += (x % 10)*pow(m, t);  //x%10 以及下面的x/10 
		x /= 10;                  //是因为输入的是int型,取数还是得用取余10的办法
		t++;
	}
	return ans;
}
string transn(int x, int n) //十进制数x转为n进制数
{
	string s;
	while (x)
	{
		s.push_back(x % n + '0');  //自己在草稿纸上演化一下10化2进制的那个流程  正着弄进去,一会倒着输出
		x /= n;
	}
	return s;
}

int main()
{
	int m,x,n;
	cin >> m>>x>>n;
	int t= transten(m, x);
	string s = transn(t, n);
	for (int i = s.size() - 1; i >= 0; i--)
	{
		cout << s[i];
	}
	return 0;
}

在这里插入图片描述
输出解释:5进制20转化为10进制为10
再转化为2进制为1010

四舍五入

看代码喽 两种方式

#include <bitset>  
#include<cmath>
#include<iomanip>
#include<iostream>
using namespace std;
int main()
{
	double n, m;
	while (cin >> n >> m)
	{
		//直接加上半个除数 计算机本来是1.多一点就省了 所以到了1.5倍直接多让他多0.5多进一位以达到四舍五入的目的
		cout << "2: " << int((n + m/2) / m) << endl;  
		              //函数,主义头文件cmath即可  math.h 也可         
		cout << "1: "/* <<fixed<<setprecision(2)*/<< round(n / m) << endl;
		
	}
}

在这里插入图片描述

本人还很菜,小总结一下,有错误啥的欢迎大家交流~

最后

以上就是单身溪流为你收集整理的笔记~ 保留位数 输出格式 进制转换 四舍五入的全部内容,希望文章能够帮你解决笔记~ 保留位数 输出格式 进制转换 四舍五入所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(90)

评论列表共有 0 条评论

立即
投稿
返回
顶部