C++003-C++变量和数据类型2

news2025/1/26 14:29:00

文章目录

  • C++003-C++变量和数据类型2
    • C++数据类型
      • 数据类型及定义
      • 数据类型及类型大小
      • 浮点数据的使用
        • **题目描述**:求阴影面积
        • **题目描述**:计算园的周长和面积
        • 如何取消科学计数法表示浮点数
        • iomanip的作用比较多:
      • 布尔变量的使用
      • 隐式转换与显式转换
        • **题目描述**:计算球的体积
        • **隐式转换规则:**
        • **显式强制类型转换C风格**
        • **显式强制类型转换C++风格**
      • 字符数据的使用
        • ASCII码
    • 课堂练习
      • 题目描述 字符与整数运行
      • 题目描述 字符大写转小写
      • 题目描述 SOS
    • 总结

C++003-C++变量和数据类型2

在这里插入图片描述

C++数据类型

数据类型及定义

在这里插入图片描述

数据类型及类型大小

1.unsigned 不影响变量存储的大小,仅影响变量取值的范围
2.指针的大小位寻址空间大小N位编译器的寻址空间大小=2 的N次方

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

浮点数据的使用

在这里插入图片描述

#include <iostream>

using namespace std;

int main()
{
    //类型一:整数位很多
    double x=12345678;
    //类型二:小数位很多,有效小数位少
    double y=0.00005678;
    //类型三:小数位很多,有效小数位也多
    double z=1.1234567;

    cout<<x<<endl;
    cout<<y<<endl;
    cout<<z<<endl;
    // 前两个数采用了科学记数法(scientific notation),第三个数保留了5位小数。
    cout<<"$$$$$$$$$$$$$$$"<<endl;


    return 0;
}

输出为:

1.23457e+07
5.678e-05
1.12346
$$$$$$$$$$$$$$$

前两个数采用了科学记数法(scientific notation),第三个数保留了5位小数。浮点数用默认记数法defaultfloat编写:这种表示方法尽可能用多的位数,这个位数包括小数点前及小数点后的位数。
默认记数法特点

1)保留有效位至多6位(有效位包括小数点前的位数,正如上文译文提到的),如 double z=1.1234567;的输出为1.12346。截取数字的规则是四舍五入
2)删去无效位数(也算是第一点的进一步说明)
double x=1.234596;
cout<<x<<endl;
的输出为1.2346,而不是1.23460
3)适当情况下会用科学记数法(scientific notation)
//类型一:整数位很多
double x=12345678;
//类型二:小数位很多,有效小数位少
double y=0.00005678;

题目描述:求阴影面积

在这里插入图片描述

在这里插入图片描述

#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
    double m,n,S,S1,S2;
    cout<<"请输入两个正方形的边长m和n,用空格或换行分割"<<endl;
    cin>>m>>n;
    S1 = 0.5*m*m;//
    S2=0.5*(n-m)*n;
    S = S1+S2;
    cout<<"阴影面积为:"<<fixed<<setprecision(2)<<S<<endl;
    return 0;
}

输出为:

请输入两个正方形的边长m和n,用空格或换行分割
10 5
阴影面积为:37.50

Process returned 0 (0x0)   execution time : 4.613 s
Press any key to continue.

题目描述:计算园的周长和面积

在这里插入图片描述

//#include <iostream>
//#include <iomanip>
//#include<cmath>
//#include <limits>
#include<bits/stdc++.h>
using namespace std;
int main()
{
    /*
    const long double pi = acos(-1.L);

    std::cout << "default precision (6): " << pi << '\n'
              << "std::setprecision(10): " << std::setprecision(10) << pi << '\n'
              << "max precision:         "
              << std::setprecision(std::numeric_limits<long double>::digits10 + 1)
              << pi << '\n';
    */
    /*
    default precision (6): 3.14159
		std::setprecision(10): 3.141592654
		max precision:         3.141592653589793239
    */
    
    double pi = 3.14;
    double r,C,S;
    cout<<"输入半径的长度"<<endl;
    cin>>r;
    C = 2*pi*r;
    S = pi*r*r;
    cout<<"园的周长为:"<<C<<endl; // 62.83185307179586232
    cout<<"园的面积为:"<<S<<endl; // 314.1592653589793258

    //cout<<"园的周长为:"<<std::setprecision(2)<<C<<endl; //63
    //cout<<"园的面积为:"<<S<<endl; // 3.1e+02

    //cout<<"园的周长为:"<<fixed<<C<<endl; //62.83
    //cout<<"园的面积为:"<<S<<endl; //314.16

    return 0;
}

输出为:

输入半径的长度
5.67
园的周长为:35.6076
园的面积为:100.948

如何取消科学计数法表示浮点数

用fixed,一个manipulator。
fixed

fixed是一个计算机专业术语,指向托管变量的指针并在 statement 执行期间“钉住”该变量。
fixed流操作符,它表示浮点输出应该以固定点或小数点表示法显示

#include <iostream>

using namespace std;

int main()
{
    //类型一:整数位很多
    double x=123456789;
    //类型二:小数位很多,有效小数位少
    double y=0.000056789;

    cout<<fixed<<x<<endl;
    cout<<fixed<<y<<endl;
    // 其实只要出现了fixed,则后面都是以fixed输出。第2行fixed不需要写了

    return 0;
}

输出为:

123456789.000000
0.000057

其实只要出现了fixed,则后面都是以fixed输出。第2行fixed不需要写了。
当 std::setprecision和std::ios::fixed一起使用时,则精度特指小数点后面保留的位数(注意和前面的区别,前面是包括小数点前面后面所有数字位数),如:上例中的 std::setprecision(10) << pi,则输出3.1415926536,不算小数点,小数点后面数字有10位

cout << setiosflags(ios::fixed) << setiosflags(ios::right) << setprecision(2);

setiosflags 是包含在命名空间iomanip中的C++ 操作符,该操作符的作用是执行由有参数指定区域内的动作;
ios::fixed 是操作符setiosflags 的参数之一,该参数指定的动作是以带小数点的形式表示浮点数,并且在允许的精度范围内尽可能的把数字移向小数点右侧;
ios::right 也是setiosflags 的参数,该参数的指定作用是在指定区域内右对齐输出;
setprecision 也是包含在命名空间iomanip 中的C++ 操作符,该操作符的作用是设定浮点数; setprecision(2) 的意思就是小数点输出的精度,即是小数点右面的数字的个数为2。
使用 setprecision(n) 可控制输出流显示浮点数的数字个数。C++默认的流输出数值有效位是6。
如果setprecision(n)与setiosflags(ios::fixed)合用,可以控制小数点右边的数字个数。
setiosflags(ios::fixed)是用定点方式表示实数

所以:
cout << setiosflags(ios::fixed) << setiosflags(ios::right) << setprecision(2);

合在一起的意思就是,输出一个右对齐的小数点后两位的浮点数。

iomanip的作用比较多:

主要是对cin,cout之类的一些操纵运算子,比如setfill, setw, setbase, setprecision等等。它是I/O流控制头文件, 就像C里面的格式化输出一样。以下是一些常见的控制函数的:

dec 置基数为10 相当于"%d"
hex 置基数为16 相当于"%X"
oct 置基数为8 相当于"%o"
setfill(c) 设填充字符为c
setprecision (n) 设显示小数精度为n位
setw (n) 设域宽为n个字符,这个控制符的意思是保证输出宽度为n。如:
cout << setw(3) << 1 << setw(3) << 10 << setw(3) << 100;
输出结果为
1 10100 (默认是右对齐)当输出长度大于3时(<<1000),setw(3)不起作用。

另外:

setioflags(ios::fixed) 固定的浮点显示
setioflags(ios::scientific) 指数表示
setiosflags(ios::left) 左对齐
setiosflags(ios::right) 右对齐
setiosflags(ios::skipws) 忽略前导空白
setiosflags(ios::uppercase) 16进制数大写输出
setiosflags(ios::lowercase) 16进制小写输出
setiosflags(ios::showpoint) 强制显示小数点
setiosflags(ios::showpos) 强制显示符号

#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
    cout<<12345.1234568 <<endl;         // 输出"12345.1"
    cout << setprecision(3) << 10.1234568  << endl;
    // 输出"10.1"
    cout << setprecision(3) << 12345.1234568 << endl;
    //输出"1.23e+004 "
    cout << setiosflags(ios::fixed) << setprecision(3) <<12345.1234568  << endl;
    //输出"12345.123 "
    cout <<setiosflags(ios::fixed) << setiosflags(ios::right) << setprecision(2)<< 10.2345 << endl;
    //输出"10.23 "
    
    cout <<setw(8)<< setiosflags(ios::fixed) << setiosflags(ios::right) << setprecision(2)<< 10.2345 << endl;
    //输出"    10.23 "
    
    cout <<setiosflags(ios::fixed) << setiosflags(ios::right) << setprecision(2)<< 10.2345 << endl;
    //输出"10.23 "
    return 0;
}

布尔变量的使用

在这里插入图片描述

隐式转换与显式转换

题目描述:计算球的体积

#include <iostream>

using namespace std;
int main()
{
    double pi = 3.14;
    double r,V;

    cout<<"输入半径的长度"<<endl;
    cin>>r;
    //V = 4/3*3.14*r*r*r; //3.14
    V = 4.0/3*3.14*r*r*r; //4.18667

    cout<<"园的体积为:"<<fixed<<V<<endl; //62.83

    return 0;
}

输出为:

输入半径的长度
1
园的体积为:3.140000

Process returned 0 (0x0)   execution time : 4.491 s
Press any key to continue.

上面的题中,发现4/3和4.0/3时的计算结果不一致,这里就出现了隐式转换的问题。

隐式转换规则:

C++语言编译系统提供的内部数据类型的隐式自动转换规则如下:
1、执行算术运算时,低类型(短字节)可以转换为高类型(长字节);例如: int型转换成double型,char型转换成int型等等;
2、赋值表达式中,等号右边表达式的值的类型自动隐式地转换为左边变量的类型,并赋值给它;
3、函数调用时,将实参的值传递给形参,系统首先会自动隐式地把实参的值的类型转换为形参的类型,然后再赋值给形参;
4、函数有返回值时,系统首先会自动隐式地将返回表达式的值的类型转换为函数的返回类型,然后再赋值给调用函数返回;

显式强制类型转换C风格

在C++基本的数据类型中,可以分为四类:整型,浮点型,字符型,布尔型。其中数值型包括 整型与浮点型;字符型即为char。
(1)将浮点型数据赋值给整型变量时,舍弃其小数部分。
(2)将整型数据赋值给浮点型变量时,数值不变,但是以指数形式存储。
(3)将double型数据赋值给float型变量时,注意数值范围溢出。
(4)字符型数据可以赋值给整型变量,此时存入的是字符的ASCII码。
(5)将一个int,short或long型数据赋值给一个char型变量,只将低8位原封不动的送到char型变量中。
(6)将有符号型数据赋值给长度相同的无符号型变量,连同原来的符号位一起传送。

显式强制类型转换C++风格

C++中强制类型转换函数有4个:
const_cast(用于去除const属性),
static_cast(用于基本类型的强制转换),
dynamic_cast(用于多态类型之间的类型转换),
reinterpreter_cast(用于不同类型之间的指针之间的转换,最常用的就是不同类型之间函数指针的转换)。

参考:C++强制类型转换

#include <iostream>

using namespace std;
int main()
{
    int a = 10;
    int b = 3;
    double result = (double)a / (double)b;
    cout<<result<<endl;

    // 使用 static_cast 关键字
    int a1 = 10;
    int b1 = 3;
    double result1 = static_cast<double>(a1) / static_cast<double>(b1);
    cout<<result1<<endl;

    return 0;
}

输出为:
在这里插入图片描述

字符数据的使用

C和C++中字符型变量只占用一个字节;
字符型变量并不是把字符本身放到内存中存储,而是将对应的ASCII码放入到存储单元。

#include <iostream>
using namespace std;

int main(){
    char ch = 'a';//要用单引号,且只能有一个字符
    cout << ch << endl;
    cout << sizeof(char) << endl;//查看字符型变量所占内存大小
    cout << (int)ch << endl;//字符型变量对应的ASCII码
    //system("pause");

    cout <<"$$$$$$$$$$$$$$"<<endl;
    //char s1;
    //cin >>s1; // 不能输入空格和换行符
    //cout <<s1 ;

    cout <<"$$$$$$$$$$$$$$"<<endl;
    char s2;
    s2 = getchar(); // 能输入空格32和换行符10
    cout << s2 <<int(s2) ;

    return 0;
}

ASCII码

在这里插入图片描述

课堂练习

题目描述 字符与整数运行

在这里插入图片描述

#include <iostream>
using namespace std;

int main(){
    char a,b;
    cin >>a; //输入A 
    cout<<"a+1 = "<<a+1<<endl; //输出a+=66
    b = a+1; //赋值,并转换为char类型
    cout<<"b = "<<b<<endl; //输出b=B

    return 0;
}

题目描述 字符大写转小写

在这里插入图片描述

#include <iostream>
using namespace std;

int main(){
    char a;
    cin >>a; //输入A
    cout<<char(a+32)<<endl; //输出a

    return 0;
}

题目描述 SOS

在这里插入图片描述

#include <iostream>
using namespace std;

int main(){
    char a,b,c;
    cin >>a>>b>>c; //输入A
    a = a-3;
    b = b-3;
    c = c-3;
    cout<<a<<b<<c<<endl; //输出a

    return 0;
}


在这里插入图片描述

总结

本系列为C++学习系列,会介绍C++基础语法,基础算法与数据结构的相关内容。本文为浮点类型,布尔类型,隐式与显示转换,字符类型的基本使用,以及相关案例练习。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/334000.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JAVA环境变量配置步骤及测试(JDK的下载 安装 环境配置教程)

一&#xff1a;JDK的下载、安装和配置1、输入下载地址&#xff1a;https://www.oracle.com/downloads/往下滑&#xff0c;看到Developer Downloads &#xff0c;点击 java点击 Java (JDK) for Developers选择你想要下载的jdk版本4、 点击 JDK Downloads &#xff0c;往下拉&…

树莓派系统创建指南

无意中发现一个落灰的树莓派 故事便开始了…… 准备工作 树莓派 3B一张大于 8G 的 micro SD 卡一个读卡器HDMI 显示器及连接线、键盘、鼠标等外围设备 系统镜像下载 推荐两个树莓派镜像下载网站 树莓派官方网站&#xff1a;https://www.raspberrypi.com/software/树莓派实…

python+request+pytest+pytest-html集成的API自动化测试框架

对于框架任何问题&#xff0c;欢迎联系我&#xff01; 需要框架源码的&#xff0c;请私聊我&#xff01; 一、框架架构 二、项目目录结构 ├────.gitignore ├────case_utils/ 测试用例相关的工具类&#xff0c;包括HTTP请求封装及用例数据处理&#xff0c;用例文件生…

常用的辅助类2(StringBuilder、StringBuffer、处理时间相关的类、对象比较器)

Java知识点总结&#xff1a;想看的可以从这里进入 目录7.7、字符串相关类7.8、时间处理7.8.1、JDK8前7.8.2、JDK8后1、时间日期类2、格式化日期3、其他7.9、对象比较器7.7、字符串相关类 String&#xff1a;JDK1.0出现&#xff0c;字符串类&#xff0c;被final修饰其值不可改。…

30个HTML+CSS前端开发案例(三)

30个HTMLCSS前端开发案例&#xff08;11-15&#xff09;小米上称右侧悬浮菜单实现代码效果图自动轮播图效果实现代码效果图小米商城二级下拉菜单效果实现代码效果图时间轴效果实现代码效果图QQ音乐排行榜效果实现代码效果图资源包获取小米上称右侧悬浮菜单 实现代码 <!DOC…

idea中使用Git

目录 一、在idea中配置Git 1、打开settings&#xff0c;搜索git&#xff0c;找到本地上的git安装目录&#xff0c;选择git.exe 2、本地git安装目录 二、获取Git 1、本地初始化仓库 2、选中项目这层目录&#xff0c;点击确定 2、从远程仓库克隆 三、本地仓库操作 1、将文…

阶段二4_常用API之StringBuilder

一. StringBuilder类概述 概述 : StringBuilder 是一个可变的字符串类&#xff0c;我们可以把它看成是一个容器&#xff0c;这里的可变指的是 StringBuilder 对象中的内容是可变的。 作用&#xff1a; 提高供字符串的操作效率 案例&#xff1a; /**证明StringBuilder提高供字…

api接口详解大全(看这篇就足以了)

api接口详解大全?优秀的设计是产品变得卓越的原因设计API意味着提供有效的接口&#xff0c;可以帮助API使用者更好地了解、使用和集成&#xff0c;同时帮助人们有效地维护它每个产品都需要使用手册&#xff0c;API也不例外在API领域&#xff0c;可以将设计视为服务器和客户端之…

函数/任意波形发生器 DG5072 技术资料

函数/任意波形发生器 DG5072 DG5000人性化的界面设计和键盘布局&#xff0c;给用户带来非凡体验&#xff1b;丰富的标准配置接口&#xff0c;可轻松实现仪器远程控制&#xff0c;为用户提供更多解决方案。 产品特性 4.3英寸16M真彩TFT液晶显示屏 350 MHz、250MHz、100 MHz或70…

Pacemaker详解、pcs命令详解和参数说明、centos8或bclinux8.2离线安装pcs以及搭建pcs、pcs的使用说明

文章目录Pacemaker详解一、前言二、 Pacemaker概述1、Pacemaker介绍2、pacemaker的服务模式。3、Pacemaker的架构4、Pacemake内部组件三、Pacemaker集群管理工具pcspcs说明最为常用的管理命令四、Pacemaker集群资源管理1、集群资源代理常用的命令方法2、集群资源约束3、集群资源…

国家政策鼓励使用电子保函和银行函证,君子签助推函证数字化建设

近日&#xff0c;国家发改委发文&#xff0c;推动电子保函应用&#xff0c;降低电子保函费用&#xff1b;财政部会同银保监会发文&#xff0c;开展数字化函证&#xff0c;有效提升函证效率和效果。政策的出台有助于加快推进普及电子函证应用。 发改委&#xff1a;鼓励使用电子…

PMP考试前两个月开始备考时间足够吗?

简单不代表报名费便宜&#xff0c;但报名费贵是肯定会难的&#xff0c;不然从何而来的含金量一说&#xff1f;花钱就能买到的话估计现在全中国持有pmp的一抓一大把。 时间完全足够的。 相信很多朋友都了解过&#xff0c;pmp的备考时间基本上是在2~3个月&#xff0c;2个月最为…

shell的变量和引用

文章目录二、变量和引用2.1 什么是变量2.2变量的命名2.3 变量的类型2.3.1 根据数据类型分类2.3.2 根据作用域分类2.4 变量的定义2.5 shell中的引用2.6 变量的运算练习&#xff1a;二、变量和引用 在程序设计语言中&#xff0c;变量是一个非常重要的概念。也是初学者在进行Shel…

计讯物联智慧灯杆网关数字赋能智慧公园,点亮城市新未来

方案背景 …… 公园作为城市景观与生态要素的空间载体&#xff0c;是市民远离尘嚣、缓解压力的理想休闲地。随着人们生活水平的提高&#xff0c;公园的信息化与智能化成为公园建设的必然方向。计讯物联依托于物联网技术&#xff0c;以绿色发展理念为指导&#xff0c;充分考虑…

/proc/cpuinfo详解

在分析该文件输出之前&#xff0c;我们先理解下几个重要的概念&#xff1a;物理CPU、CPU核心数、逻辑CPU。 物理CPU数&#xff08;physical id&#xff09;&#xff1a;主板上实际插入的cpu数量&#xff0c;不重复的 physical id 有几个就有多少个物理CPU。 CPU核心数&#xf…

95. 不同的二叉搜索树 II

95. 不同的二叉搜索树 II题目算法设计&#xff1a;深度优先搜索题目 传送门&#xff1a;https://leetcode.cn/problems/unique-binary-search-trees-ii/ 算法设计&#xff1a;深度优先搜索 二叉树子问题分解 根节点 左右子树的子问题。 根节点的子问题&#xff1a;循环历遍…

高压放大器由哪些部分组成?如何验证它性能的好坏?

虽然很多电子工程师经常使用高压放大器&#xff0c;但是对于高压功率放大器的组成和使用都不太清楚&#xff0c;下面由安泰测试给大家介绍高压放大器的组成部分以及如何验证功率放大器的性能好坏。 一、高压放大器的介绍 高压放大器是一种理想的功率放大器&#xff0c;可以放…

企业版快速开发框架源码 Spring Cloud快速开发脚手架源码

一款 Java 语言基于Spring Cloud Alibaba、SpringBoot、Mybatis、Seata、Sentinel、RabbitMQ、FastDFS/MinIO、SkyWalking等主要框架和中间件&#xff0c;精心打造的一款模块化、插件化、高性能的快速开发框架&#xff0c;可用于快速搭建后台管理系统。 私信了解更多&#xff…

(九)docker复杂安装-安装mysql主从复制

目录 前提&#xff1a; 一、新建主服务器容器实例3307 二、进入/mydata/mysql-master/conf目录下新建my.cnf 三、修改完配置后重启master实例 四、进入mysql-master容器并测试 五、master容器实例内创建数据同步用户 六、新建从服务器容器实例3308 七、进入/mydata/mys…

提取接近竖直物体(粗定位)

由于项目的需要提取图像之中的一个接近于竖直的物体&#xff0c;一般的方法是进行图像分割&#xff0c;分割方式使用什么OTSU方式以及hsv方法等等。但是项目中使用的相机是黑白相机&#xff0c;会受到一定的限制。因此想到的是使用线条提取方式。线条提取方式之中最好的方法是使…