一,上次的课后练习答案

1,输出1+2=3

2,输出2 2.25 2.25 2.25

3,第一空iostream或bits/stdc++.h

第二空main(),main(void)或main(int argc,char* argv[])

第三空(1.0+2.0+3.0)

第四空return

二,变量的赋值和大小

今天我们开始讲变量相关的内容。变量存储在内存里面。

例如上图,我们定义一个叫做a的变量,并把这个变量设置为10。我们可以写如下的语句。

#include<iostream>
using namespace std;
int main(){
int a=10;
}

实际上,变量既可以定义在main里面,也可以定义在main外面。

#include<iostream>
using namespace std;
int a=10;
int main(){
}

这两种定义方式的区别我们等到以后再讲。

int表示这个变量用于存储整数。如果要存储小数,我们可以使用float或者是double类型。

#include<iostream>
using namespace std;
int main(){
float x=1.2;
}

如果是存储字符,我们可以用char类型。

#include<iostream>
using namespace std;
int main(){
char c='A';//字符用单引号括起来
cout<<c;
}

存储了变量后,我们如何输出变量呢?

非常简单,我们直接用cout即可。

#include<iostream>
using namespace std;
int main(){
float x=1.2;
cout<<x;
return 0;
}

【题目】计算2147483647+1的值。

#include<iostream>
using namespace std;
int main(){
int a=2147483647,b=1;
cout<<a+b;
}

输出:-2147483648

看来这程序有问题。int类型可以存储-2147483648到2147483647的整数,对于2147483647,它超限了,所以溢出,输出了一个错误数据。我们可以使用long long类型来存储264以内的数。

#include<iostream>
using namespace std;
int main(){
long long a=2147483647,b=1;
cout<<a+b;
}

事实上,只需要其中一个变量定义为long long,结果就为long long了。

#include<iostream>
using namespace std;
int main(){
long long a=2147483647;
int b=1;
cout<<a+b;
}

常用变量的范围(根据不同的环境可能会有差异)

short 短整型 -32768..32767

int 整型 -2147483648..2147483647

long long 长整型 -9 223 372 036 854 775 808..9 223 372 036 854 775 807

float 单精度浮点数 -3.4E-38..3.4E+38

double 双精度浮点数 -1.7E-308..1.7E+308

char 字符型 -128..127

三,课后练习一

1,阅读程序写结果:

#include<iostream>
using namespace std;
int main(){
int a=8;
cout<<"a="<<a;
return 0;
}

2,阅读理解:

sizeof(变量)可以求出变量所占内存的大小。例如,sizeof(x),如果x为int类型的变量,由于int占4字节,sizeof(x)返回4.

试求出下面程序的运行结果:

#include<iostream>
using namespace std;
int main(){
long long a;
cout<<sizeof(a);
}

3,完善程序:

求出一个数加上0.2向下取整后的数值。假定这个数为变量a。

#include<iostream>
using namespace std;
int main(){
float a=1.7;
cout<<__(1)___ ( a ___(2)___);
return 0;
}

四,变量的赋值和运算

【题目】阅读程序写结果。

#include<iostream>
using namespace std;
int main(){
int a,b;
a=2;
b=a+1;
cout<<"b="<<b<<endl;
}

b=a+1,把a+1的值给到b,因为a=2,所以a+1=3,所以b=3。

【题目】a=2,让a的值加上1后输出。

#include<iostream>
using namespace std;
int main(){
int a=2;
a=a+1;
cout<<a;
return 0;
}

a=a+1一句表示把a+1的值给到a,因为a=2,所以a+1=3,相当于把3给到a,所以a=3。

其实a=a+1一句还有简便写法。

#include<iostream>
using namespace std;
int main(){
int a=2;
a+=1;
cout<<a;
return 0;
}

a=a+b类似的语句,可以写成a+=b。同理,

a=a-b等同于a-=b

a=a*b等同于a*=b

a=a/b等同于a/=b

a=a%b等同于a%=b

如果让变量的值增加1或者减少1,我们还有一种写法。

a++ 和 ++a 都表示a+=1.

a-- 和 --a 都表示a-=1

但是,++(--)放在前面和放在后面有什么区别呢?

//程序段1
#include<iostream>
using namespace std;
int main(){
int a=0;
cout<<++a<<endl;
cout<<a;
}
//程序段2
#include<iostream>
using namespace std;
int main(){
int a=0;
cout<<a++<<endl;
cout<<a;
}

我们测试一下,运行的结果是:

程序段1:1 1

程序段2:0 1

我们发现++和--的特性:

前置的++(或--)先+1,再执行语句中的操作(如输出)

后置的++(或--)先执行语句中的操作(如输出),再+1

五,课后练习二

1,阅读程序写结果:

#include<iostream>
using namespace std;
int main(){
int a,b;
a=1;b=1;
a=b++;cout<<a<<" "<<b<<endl;
a=++b;cout<<a<<" "<<b<<endl;
return 0;
}

2,完善程序:已知一个三位数123,将它倒序输出。

#include<iostream>
using namespace std;
int main(){
int a=123;
int gw,sw,bw;//个位,十位,百位
gw=a%__(1)___;
sw=a/__(2)__%10;
bw=a/__(3)__;
cout<<gw<<__(4)__<<__(5)__;
return 0;
}

【C++基础教程】第二课的更多相关文章

  1. NeHe OpenGL教程 第二课:多边形

    前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线教程的编写,以及yarn的翻译整理表示感谢 ...

  2. Android OpenGL教程-第二课【转】

    第二课 你的第一个多边形: 在第一个教程的基础上,我们添加了一个三角形和一个四边形.也许你认为这很简单,但你已经迈出了一大步,要知道任何在OpenGL中绘制的模型都会被分解为这两种简单的图形. 读完了 ...

  3. CI(CodeIgniter)框架入门教程——第二课 初始MVC

    本文转载自:http://www.softeng.cn/?p=53 今天的主要内容是,使用CodeIgniter框架完整的MVC内容来做一个简单的计算器,通过这个计算器,让大家能够体会到我在第一节课中 ...

  4. [原创]零基础R语言教程---第二课---R语言入门

    这节教程简单描述了R语言中常用的数据类型, 向量,字符串,矩阵,列表,数据框,以及附带了一个小例子 对于这节课所附带的例子需要做下列补充: 1.这个例子面向于对整列的数据进行预测 2.如果你需要求单行 ...

  5. Jquery基础教程第二版学习记录

    本文仅为个人jquery基础的学习,简单的记录以备忘. 在线手册:http://www.php100.com/manual/jquery/第一章:jquery入门基础jquery知识:jquery能做 ...

  6. Ruby 基础教程 第二部分 Ruby 的基础 第4章

    第二部分 Ruby 的基础 第4章~第6章 这一部分是 Ruby 编程需要遵守的规则. 第四章 对象,变量与常量 对象 & 类 对象的常见种类: 数值对象 字符串对象 数组.散列对象 正则表达 ...

  7. python基础教程-第二章-列表和元组

    本章将引入一个新的概念,:数据结构.数据结构是通过某种方式(例如对元素进行编号)组织在 一起的数据元素的集合,这些数据元素可以是数字或者字符,甚至可以是其他数据结构.在python中,最基本的数据结构 ...

  8. PHP基础教程-54课-问题

    question: $arr = array(1,2,3,4); /*如何通过foreach 将数组变成 $arr = arry(2,4,6,8) */ 起初用: $arr = array(1,2,3 ...

  9. C语言基础课程 第二课 HelloWorld不为菜鸟所知的秘密

    1    愉快的开端hello world    4 1.1    include头文件包含    4 1.2    main函数    4 1.3    注释    4 1.4    {}括号,程序 ...

  10. 第二章、元组和列表(python基础教程第二版 )

    最基本的数据结构是序列,序列中每个元素被分配一个序号-元素的位置,也称索引.第一个索引为0,最后一个元素索引为-1. python中包含6种内建的序列:元组.列表.字符串.unicode字符串.buf ...

随机推荐

  1. 使用Eclipse下载CRaSH源代码

    Eclipse for Java Developers (Juno)本身有一个eGit组件,通过它可以直接从Git源码库中下载源代码,以下载 CRaSH 为例说明: 从主页上的"Develo ...

  2. Haskell Interactive Development in Emacs

    Installation Following haskell-mode. Use MELPA repository: add the following into ~/.emacs (require ...

  3. 计算机网络:基于iptalbes的SANT和DNAT|docker的服务器发布项目--超详细一看就会

     项目说明: 模拟企业让内网服务器可以上网,同时发布内网的服务器 1.实验环 我们需要准备三台linux系统,一台作为路由器机route,其它为客户机client-1.client-2 主机改名 ho ...

  4. 带你读AI论文丨用于目标检测的高斯检测框与ProbIoU

    摘要:本文解读了<Gaussian Bounding Boxes and Probabilistic Intersection-over-Union for Object Detection&g ...

  5. hdmi 随笔

    从图片来看,每张图片开始传输的是45像素的垂直同步, 1.控制数据贯穿所有时间,没个不是控制数据的传输都被控制数据包围.控制数据还要通过控制位指示,下一个数据是数据岛还是视频信号. 2.terc4 全 ...

  6. Slope Trick:解决一类凸代价函数DP优化

    [前言] 在补Codeforce的DP时遇到一个比较新颖的题,然后在知乎上刚好 hycc 桑也写了这道题的相关题解,这里是作为学习并引用博客的部分内容 这道题追根溯源发现2016年这个算法已经在API ...

  7. L298N使用资料

    L298N驱动连接arduino小车电机(代码和使用): https://www.cnblogs.com/fsong/p/12309911.htmlarduino UNO 连接L298N驱动两个电机转 ...

  8. ASP.NET Core教程:ASP.NET Core使用AutoMapper

    一.前言 在实际的项目开发过程中,我们使用各种ORM框架可以使我们快捷的获取到数据,并且可以将获取到的数据绑定到对应的List<T>中,然后页面或者接口直接显示List<T>中 ...

  9. axios 请求数据跳转页面报'$router' of undefined问题

    代码: this.$axios.post("/auth", { 'username': this.username, 'password': this.password }).th ...

  10. HttpClient 4.3教程-前言

    前言 Http协议应该是互联网中最重要的协议.持续增长的web服务.可联网的家用电器等都在继承并拓展着Http协议,向着浏览器之外的方向发展. 虽然jdk中的java.net包中提供了一些基本的方法, ...