【C++基础教程】第二课
一,上次的课后练习答案
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++基础教程】第二课的更多相关文章
- NeHe OpenGL教程 第二课:多边形
前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线教程的编写,以及yarn的翻译整理表示感谢 ...
- Android OpenGL教程-第二课【转】
第二课 你的第一个多边形: 在第一个教程的基础上,我们添加了一个三角形和一个四边形.也许你认为这很简单,但你已经迈出了一大步,要知道任何在OpenGL中绘制的模型都会被分解为这两种简单的图形. 读完了 ...
- CI(CodeIgniter)框架入门教程——第二课 初始MVC
本文转载自:http://www.softeng.cn/?p=53 今天的主要内容是,使用CodeIgniter框架完整的MVC内容来做一个简单的计算器,通过这个计算器,让大家能够体会到我在第一节课中 ...
- [原创]零基础R语言教程---第二课---R语言入门
这节教程简单描述了R语言中常用的数据类型, 向量,字符串,矩阵,列表,数据框,以及附带了一个小例子 对于这节课所附带的例子需要做下列补充: 1.这个例子面向于对整列的数据进行预测 2.如果你需要求单行 ...
- Jquery基础教程第二版学习记录
本文仅为个人jquery基础的学习,简单的记录以备忘. 在线手册:http://www.php100.com/manual/jquery/第一章:jquery入门基础jquery知识:jquery能做 ...
- Ruby 基础教程 第二部分 Ruby 的基础 第4章
第二部分 Ruby 的基础 第4章~第6章 这一部分是 Ruby 编程需要遵守的规则. 第四章 对象,变量与常量 对象 & 类 对象的常见种类: 数值对象 字符串对象 数组.散列对象 正则表达 ...
- python基础教程-第二章-列表和元组
本章将引入一个新的概念,:数据结构.数据结构是通过某种方式(例如对元素进行编号)组织在 一起的数据元素的集合,这些数据元素可以是数字或者字符,甚至可以是其他数据结构.在python中,最基本的数据结构 ...
- PHP基础教程-54课-问题
question: $arr = array(1,2,3,4); /*如何通过foreach 将数组变成 $arr = arry(2,4,6,8) */ 起初用: $arr = array(1,2,3 ...
- C语言基础课程 第二课 HelloWorld不为菜鸟所知的秘密
1 愉快的开端hello world 4 1.1 include头文件包含 4 1.2 main函数 4 1.3 注释 4 1.4 {}括号,程序 ...
- 第二章、元组和列表(python基础教程第二版 )
最基本的数据结构是序列,序列中每个元素被分配一个序号-元素的位置,也称索引.第一个索引为0,最后一个元素索引为-1. python中包含6种内建的序列:元组.列表.字符串.unicode字符串.buf ...
随机推荐
- 启动或重启Oracle数据以及监听
(以下均为命令行形式) 1.切换到oracle数据库用户: su - oracle 2.查看数据库的监听状态: lsnrctl status 3.停止监听: lsnrctl stop 4.登陆到ora ...
- tomcat服务监控分析及自启
#! /bin/bash # process-monitor.sh serverName="/usr/local/apache-tomcat-7.0.72-8080" #获取进程i ...
- Linux服务器下JVM堆栈信息dump及问题排查
#dump 方法栈信息 jstack $pid > /home/$pid/jstack.txt #dump jvm内存使用情况 jmap -heap $pid > /home/$pid/j ...
- eclipse中添加进新的java项目中文乱码
eclipse中添加进新的java项目中文乱码 添加学习的一些项目进eclipse中,结果其中的中文注释都变成了乱码 右击项目,点最下面的属性,出来新得弹框 在文本文件编码部分可以发现是GBK格式,选 ...
- Pikachu-Unsafe Filedownload模块
一.概述 文件下载功能在很多web系统上都会出现,一般我们当点击下载链接,便会向后台发送一个下载请求,一般这个请求会包含一个需要下载的文件名称,后台在收到请求后 会开始执行下载代码,将该文件名对应的文 ...
- STM32—位带操作
STM32中的位带操作: 名字为位带操作,实际上是对位的操作,位操作就是可以单独的对一个比特位读和写,这个在 51 单片机中非常常见. 51 单片机中通过关键字 sbit 来实现位定义, STM32 ...
- SQL 练习17
查询各科成绩最高分.最低分和平均分: 以如下形式显示:课程 ID,课程 name,最高分,最低分,平均分,及格率,中等率,优良率,优秀率 , 及格为>=60,中等为:70-80,优良为:80-9 ...
- noip30
T1 一眼看,觉得是个状压,然而又觉得不太行,去打暴力了,然而暴力都打挂的我biss. 正解: 还是暴力,考虑 \(meet \; in \; the \; middle\) 显然对于每个数,只有三种 ...
- NOIP 模拟 $33\; \rm Hunter$
题解 \(by\;zj\varphi\) 结论题. 对于 \(1\) 猎人,他死的期望就是有多少个死在它前面. 那么对于一个猎人,它死在 \(1\) 前的概率就是 \(\frac{w_i}{w_i+w ...
- [转]用C++实现插件体系结构
本文讨论一种简单却有效的插件体系结构,它使用C++,动态链接库,基于面向对象编程的思想.首先来看一下使用插件机制能给我们带来哪些方面的好处,从而在适当时候合理的选择使用. 1. 增强代码的透明度与一致 ...