一,上次的课后练习答案

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. Linux命令(四)之常用文件拷贝/移动,文件解压缩,文件查找等相关的操作

    .personSunflowerP { background: rgba(51, 153, 0, 0.66); border-bottom: 1px solid rgba(0, 102, 0, 1); ...

  2. 列出文件夹中分级目录java

    package test; import java.io.File; public class exportFileName { public static void main(String[] ar ...

  3. Git-04-本地仓库撤销修改

    编辑修改了文件,但是还没有git add之前 直接用 git checkout -- filename 这个命令就可以了 已经 git add 了,但是没有 git commit 之前 1 模拟git ...

  4. 网络安全学习阶段性总结:SQL注入|SSRF攻击|OS命令注入|身份验证漏洞|事物逻辑漏洞|目录遍历漏洞

    目录 SQL注入 什么是SQL注入? 掌握SQL注入之前需要了解的知识点 SQL注入情况流程分析 有完整的回显报错(最简单的情况)--检索数据: 在HTTP报文中利用注释---危险操作 检索隐藏数据: ...

  5. 谈谈ARM运行C程序的内部机制

    文章目录 一.代码 二.知识储备 1.ARM汇编指令 2.寄存器知识 三.代码解析 1.指令分析 第一条指令: 第二条指令: 第三条指令: 第四条指令: 第五.六条指令: 第七条指令: 第八.九.十条 ...

  6. SQL 练习38

    查询选修了全部课程的学生信息 SELECT * from Student WHERE SId IN ( SELECT sid from sc GROUP BY sid HAVING COUNT(cid ...

  7. SQL 练习18

    按各科成绩进行排序,并显示排名, Score 重复时保留名次空缺 SELECT t.cid,t.sid,t.score ,COUNT(t1.score)+1 as 排名 from sc as t LE ...

  8. 三个线程按循序一个打印A一个打印B一个打印C 循环打印?

    第一种 public static volatile int flag = 1; public static void printABC1(){ Thread t1 = new Thread(() - ...

  9. jenkins部署web项目

    Dockerfile FROM nginx:latest #MAINTAINER 维护者信息 MAINTAINER GosingWu 1649346712@qq.com ADD admin_test. ...

  10. C#简单实现表达式目录树(Expression)

    1.什么是表达式目录树 :简单的说是一种语法树,或者说是一种数据结构(Expression) 2.用Lambda声明表达式目录树: 1 2 3 4 5 Expression<Func<in ...