1.

 #include <iostream>
#include <vector>
#include <string>
using namespace std; // 函数声明
void output1(vector<string> &);
void output2(vector<string> &); int main()
{
vector<string>likes, dislikes; // 创建vector<string>对象likes和dislikes int n;
cin>>n;
getchar(); int i=;
for(i=;i<n;i++){
string a;
getline(cin,a);
likes.push_back(a);
}
// 为vector<string>数组对象likes添加元素值 ( favorite book, music, film, paintings,anime,sport,sportsman,etc)
// 补足代码
// 。。。 cout << "-----I like these-----" << endl;
// 调用子函数输出vector<string>数组对象likes的元素值
// 补足代码
// 。。。
output1(likes); // 为vector<string>数组对象dislikes添加元素值
// 补足代码
// 。。。
for(i=;i<n;i++){
string b;
getline(cin,b);
dislikes.push_back(b);
} cout << "-----I dislike these-----" << endl;
// 调用子函数输出vector<string>数组对象dislikes的元素值
// 补足代码
// 。。。
output2(dislikes); // 交换vector<string>对象likes和dislikes的元素值
// 补足代码
// 。。。
likes.swap(dislikes); cout << "-----I likes these-----" << endl;
// 调用子函数输出vector<string>数组对象likes的元素值
// 补足代码
// 。。。
output1(likes);
cout << "-----I dislikes these-----" << endl;
// 调用子函数输出vector<string>数组对象dislikes的元素值
// 补足代码
// 。。。
output2(dislikes); return ;
} // 函数实现
// 以下标方式输出vector<string>数组对象v的元素值
void output1(vector<string> &v) {
// 补足程序
// 。。。
for(int i=; i<v.size(); ++i)
cout << v[i]<<" ";
cout<<endl;
} // 函数实现
// 以迭代器方式输出vector<string>数组对象v的元素值
void output2(vector<string> &v) {
// 补足程序
// 。。。
for(int i=; i<v.size(); ++i)
cout << v[i]<<" ";
cout<<endl;
}

运行截图:

2.        6-17

 #include<iostream>
using namespace std;
int main(){
int *p;
int a=;
p=&a;//指针p的值等于常量,并且p在内存中没有指向
cout<<"The value at p:"<<*p;
return ;
}

运行截图:

6-18:

 #include<iostream>
using namespace std;
int fn1(){
int *p=new int ();//这句是从堆上分配一个int型变量所占的字节内存,这个内存单元存放的整数值为5,然后让一个整形的指针变量p指向它的地址。 return *p;
delete p;//释放内存空间
}
int main(){
int a=fn1();
cout<<"The value of a is:"<<a; return ;
}

截图:

注:这个例子中,如果不释放内存,程序仍然会运行出正确结果,那么不释放内存能带来哪些坏处呢?使用new分配内存,不加以释放,会导致动态分配的内存无法回收,使得程序占据的内存越来越大。我想,这需要反汇编才能看出不同。

3.Matrix.h

#ifndef MATRIX_H
#define MATRIX_H
class Matrix {
public:
Matrix(int n); // 构造函数,构造一个n*n的矩阵
Matrix(int n, int m); // 构造函数,构造一个n*m的矩阵
Matrix(const Matrix &X); // 复制构造函数,使用已有的矩阵X构造
~Matrix(); //析构函数
void setMatrix(const float *pvalue); // 矩阵赋初值,用pvalue指向的内存块数据为矩阵赋值
void printMatrix() const; // 显示矩阵
inline float &element(int i, int j){return *(p+((i-)*cols)+j-);} //返回矩阵第i行第j列元素的引用
inline float element(int i, int j) const{return *(p+((i-)*cols)+j-);}// 返回矩阵第i行第j列元素的值
void setElement(int i, int j, int value); //设置矩阵第i行第j列元素值为value
inline int getLines() const{ return lines;}//返回矩阵行数
inline int getCols() const {return cols;} //返回矩阵列数
private:
int lines; // 矩阵行数
int cols; // 矩阵列数
float *p; // 指向存放矩阵数据的内存块的首地址
};
#endif

matrix.cpp

 #include"matrix.h"
#include<iostream>
using namespace std; Matrix::Matrix(int n):lines(n),cols(n){// 构造函数,构造一个n*n的矩阵
p=new float[lines*cols]; }
Matrix::Matrix(int n,int m):lines(n),cols(m){ p=new float [lines*cols]; }
Matrix::Matrix(const Matrix &X){
lines=X.lines;
cols=X.cols;
p=new float [lines*cols];
for(int i=;i<lines*cols;i++)
p[i]=X.p[i]; } void Matrix::setMatrix(const float *pvalue){ for(int i=;i<cols*lines;i++){
p[i]=pvalue[i];
} cout<<"ceshi2"<<endl; } void Matrix::printMatrix() const{
int i,j;
for(i=;i<lines;i++){
for(j=;j<cols;j++){
cout<< p[i*cols + j]<<' ';
}
cout<<endl; } } void Matrix::setElement(int i,int j,int value){
p[(i-)*cols + j-]=value;
}
Matrix::~Matrix(){
delete []p;
}

main.cpp

#include"matrix.h"
#include<iostream>
using namespace std;
int main(){
int n;
cin>>n;
Matrix a(n);//定义一个3*3的矩阵
float c[n*n];
cout<<"赋值:"<<endl;
for(int i=;i<n*n;i++)
cin>>c[i];
a.setMatrix(c);
cout<<"输出"<<endl;
a.printMatrix();
cout<<"输出修改后的值"<<endl;
a.setElement(,,);
cout<<"输出"<<endl;
a.printMatrix();
Matrix b(,);
cout<<"赋值:"<<endl;
float d[];
for(int i=;i<;i++)
cin>>d[i];
b.setMatrix(d);
cout<<"输出"<<endl;
b.printMatrix();
cout<<"输出列"<<endl;
cout<< b.getCols()<<endl;
cout<<"输出行"<<endl;
cout<<b.getLines()<<endl;
cout<<"输出第3行第一个元素"<<endl;
cout<<b.element(,)<<endl; return ; }

运行截图:

4.这次的最后一个实验用了很长时间,甚至最后看了不少其他同学的代码才写出来一份完整的来。只看书不动手万万不可!!

【C++ 实验5 类和对象】的更多相关文章

  1. c++实验3类和对象

     实 验 3: part 1:验证 part 2:graph #include <iostream> #include "graph.h" using namespac ...

  2. C++ 实验3 类和对象

    Part 2 #ifndef GRAPH_H #define GRAPH_H class Graph { public: Graph(char ch, int n); void draw(); pri ...

  3. 【C++/实验三】类和对象

    1.定义一个矩形类,有长,宽两个属性,有成员函数计算矩形的面积. 在该矩形类中,我做了5个主要的测试. 构造函数带默认值参数,利用默认值参数计算矩形面积:rectangle(double x=2.0, ...

  4. 第四周总结和实验二Java简单类与对象

    实验目的 掌握类的定义,熟悉属性.构造函数.方法的使用,掌握用类作为类型声明变量和方法返回值: 理解类和对象的区别,掌握构造函数的使用,熟悉通过对象名引用实列的方法和属性: 理解static修饰对类. ...

  5. C++ Daily 《6》---- 类静态对象与函数静态对象

    C++ 的一个哲学基础是,你不应该为你使用的东西付出代价. class 拥有一个 static 成员,即使从未被用到,它也会被构造和析构: 而 函数拥有一个 static 成员, 如果这个函数从未被调 ...

  6. iOS RunTime运行时(1):类与对象

    Objective-C语言是一门动态语言,他将很多静态语言在编译和链接期做的事放到了运行时来处理.这种动态语言的优势在于:我们写代码更具有灵活性,如我们可以把消息转发给我们想要的对象,或者随意交换一下 ...

  7. JAVA入门第二季 第一章 类和对象

    面向对象编程 Object Oriented Programming OOP 第一.什么是类和对象 在具体说明类和对象之前,先说说别的. 眼睛在人类身体上最为有用的器官.如果一个没有了眼睛,这个人与世 ...

  8. php学习小记2 类与对象

    php类的一些特性: 1. 伪变量$this.$this是一个到主叫对象的引用.取值:该方法所从属的对象,可能是另外的对象(前提,当该方法被静态调用时).$this变量存在于一个类的非静态方法中,在静 ...

  9. 非常易于理解‘类'与'对象’ 间 属性 引用关系,暨《Python 中的引用和类属性的初步理解》读后感

    关键字:名称,名称空间,引用,指针,指针类型的指针(即指向指针的指针) 我读完后的理解总结: 1. 我们知道,python中的变量的赋值操作,变量其实就是一个名称name,赋值就是将name引用到一个 ...

随机推荐

  1. u3d不显示阴影的处理方法

    正常情况下都会显示的,如果没有显示,尝试以下几种方案: 1)缩小模型看一看 2)旋转灯光试试,看是否有阴影 3)检查阴影设置 菜单栏Edit –> Project Settings –> ...

  2. nginx配置实例

    user root root; worker_processes ; #error_log logs/error.log; #error_log logs/error.log notice; #err ...

  3. Centos yum国内源及配置含义

    Centos yum源的位置: /etc/yum.repos.d,可以通过配置文件/etc/yum.conf指定其他位置 主要的yum源种类:前两个是必须的,不然yum安装很多软件时会失败.yum本来 ...

  4. C# IOThread

    在看微软的ASP.NET - 将 ASP.NET 用作高性能文件下载器 示例里面用到了IO 线程,以前打算自己撸的,这里贴出来 已标记一下: ///////////////////////////// ...

  5. 中国大学MOOC-陈越、何钦铭-数据结构-2017春

    中国大学MOOC-陈越.何钦铭-数据结构-2017春 学习地址 详细学习内容 Github记录地址 欢迎fork和star,有惊喜值得学习! 参考学习笔记 参考AC代码 数据结构和算法学习笔记 学习内 ...

  6. 小白入门使用Nginx基础的常用操作

    nginx启动,重启,关闭命令 停止操作 停止操作前需要ps当前Nginx的所有进程 步骤1:查询nginx主进程号 ps -ef | grep nginx 在进程列表里 面找master进程,它的编 ...

  7. 海康威视(iOS集成)

    一.注意事项 1.在开发海康威视的SimpleDemo时,最好使用真机,因为海康提供的5个库不支持模拟的i386架构. 2.在XCode9.3版本上运行SimpleDemo时,对.mm文件进行编辑时, ...

  8. 每天一个linux命令(4):mkdir

    1.命令简介 mkdir (Make Directory 创建目录): 若指定目录不存在则创建目录.在创建目录时,要求创建目录的用户具有写权限,并应保证新建的目录没有重名. 2.用法 用法:mkdir ...

  9. 转 Java虚拟机5:Java垃圾回收(GC)机制详解

    转 Java虚拟机5:Java垃圾回收(GC)机制详解 Java虚拟机5:Java垃圾回收(GC)机制详解 哪些内存需要回收? 哪些内存需要回收是垃圾回收机制第一个要考虑的问题,所谓“要回收的垃圾”无 ...

  10. ANTLR v4 权威参考笔记(目录)

    ANTLR v4是一款强大的语法分析器生成器,可以用来读取.处理.执行和转换结构化文本或二进制文件.通过称为文法的形式化语言描述,ANTLR可以为该语言自动生成词法分析器.生成的语法分析器可以自动构建 ...