首页 > 其他分享 >实验六

实验六

时间:2022-12-06 22:25:34浏览次数:40  
标签:capacity int length Vector 实验 include data

#include <iostream>
#include <fstream>
#include <array>
#define N 5
 
int main() {
    using namespace std;
 
    array<int, N> x {97, 98, 99, 100, 101};
 
    ofstream out;
    out.open("data1.dat", ios::binary);
    if(!out.is_open()) {
        cout << "fail to open data1.dat\n";
        return 1;
    }
 
    out.write(reinterpret_cast<char *>(&x), sizeof(x));
    out.close();
}
#include <iostream>
#include <fstream>
#include <array>
#define N 5
 
int main() {
    using namespace std;
    array<int, N> x;
 
    ifstream in;
    in.open("data1.dat", ios::binary);
    if(!in.is_open()) {
        cout << "fail to open data1.dat\n";
        return 1;
    }
 
    in.read(reinterpret_cast<char *>(&x), sizeof(x));
    in.close();
 
    for(auto i = 0; i < N; ++i)
        cout << x[i] << ", ";
    cout << "\b\b \n";
}

 

 

实验四:

#pragma once
#include<iostream>
using namespace std;
 
template<typename T>
class Vector
{
public:
    Vector(int capacity);
    Vector(int length, T value);
    Vector(const Vector& obj);
    ~Vector();
    int get_size()const;
    T& at(int i);
    T& operator[](int i);
    friend void output(const Vector<T>& obj);
private:
    T* _data;
    size_t _capacity;
    size_t _length;
};
 
template<typename T>
Vector<T>::Vector(int capacity) :_data(new T[capacity]), _capacity(capacity), _length(capacity)
{}
 
template<typename T>
Vector<T>::Vector(int length, T value) :_data(new T[length]), _capacity(length), _length(length)
{
    for (int i = 0; i < length; i++)
        _data[i] = value;
}
 
template<typename T>
Vector<T>::Vector(const Vector& obj)
{
    _data = new T[obj._capacity];
    _capacity = obj._capacity;
    _length = obj._length;
    for (int i = 0; i < _length; i++)
        _data[i] = obj._data[i];
}
 
template<typename T>
Vector<T>::~Vector()
{
    delete []_data;
    _length = 0;
    _capacity = 0;
    _data = nullptr;
}
 
template<typename T>
int Vector<T>:: get_size() const
{
    return _length;
}
 
template<typename T>
T& Vector<T>::at(int i)
{
    return _data[i];
}
 
template<typename T>
T& Vector<T>:: operator[](int i)
{
    return _data[i];
}
 
void output(const Vector<int>& obj)
{
    for (int i = 0; i < obj._length; i++)
        cout << obj._data[i] << ",";
    cout << endl;
}
 
void output(const Vector<double>& obj)
{
    for (int i = 0; i < obj._length; i++)
        cout << obj._data[i] << ",";
    cout << endl;
}
#include <iostream>
#include "Vector.h"
 
void test() {
    using namespace std;
 
    int n;
    cin >> n;
 
    Vector<double> x1(n);
    for (auto i = 0; i < n; ++i)
        x1.at(i) = i * 0.7;
 
    output(x1);
 
    Vector<int> x2(n, 42);
    Vector<int> x3(x2);
 
    output(x2);
    output(x3);
 
    x2.at(0) = 77;
    output(x2);
 
    x3[0] = 999;
    output(x3);
}
 
int main() {
    test();
}

 

 

实验五:

#include<iostream>
#include<string>
#include<iomanip>
#include<fstream>
using std::ofstream;
using std::endl;
using std::setw;
std::string stand = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
void output(std::ostream& out)
{
    int row = 1;
    out << "   ";
    for (int i = 0; i < 26; i++)
        out << (char)(stand[i] + 32) << " ";
    out << endl;
    while (row <= 26)
    {
        out << setw(2) << row << " ";
        for (int i = 0; i < 26; i++)
            out << stand[(i + row) % 26] << " ";
        out << endl;
        row++;
    }
}
int main()
{
    ofstream out;
    out.open("ciper.txt");
    if (!out.is_open())
    {
        std::cout << "fail to open ciper.txt" << endl;
        return 1;
    }
    output(out);
    output(std::cout);
    return 0;
}

 

标签:capacity,int,length,Vector,实验,include,data
From: https://www.cnblogs.com/dailu666666/p/16960837.html

相关文章

  • 实验六
    #pragmaonce#include<iostream>usingstd::cout;usingstd::endl;template<typenameT>classVector{public:Vector(Tn):size(n){p=newT[n];}V......
  • 实验六
    实验任务3#include<iostream>#include<fstream>#include<array>#defineN5intmain(){usingnamespacestd;array<int,N>x{97,98,99,100,......
  • 实验六 模板类和文件IO
    任务四代码:Vector.hpp:#pragmaonce#include<iostream>usingnamespacestd;template<classT>classVector{public:Vector(intsize0):size{size......
  • 实验六 模板类和文件IO
    Task4//VEctor.hpp#include<bits/stdc++.h>usingnamespacestd;template<typenameT>classVector{private:intlength;T*base;publ......
  • 包层次的时间同步实验
    一、实验目的理解掌握时间同步的重要意义了解时间同步的基本方法,理解TPSN协议机理掌握TinyOS定时器相关接口和组件的使用4.能够在TinyOS中实现多节点间的时间......
  • SRP实验
    一、实验目的学习源路由协议的机制理解节点在源路由协议中的几种角色掌握源路由协议相关接口SourceRouteSend、SourceRoutePacket的使用 二、实验要求功能:root......
  • Dissemination实验
    一、实验目的学习少量数据在传感网中可靠传递的方法掌握TinyOS中DisseminationValue、DisseminationUpdate接口和组件的使用理解Dissemination的机制 二、实......
  • LEEP节点无线链路质量评估实验
    一、实验目的理解节点通信链路质量的影响因素理解提升链路质量的一般方法学习TinyOS系统中CC2530/CC2538节点发送功率的设置体验不同发送功率、不同通信距离、不......
  • 实验6
    task3_1:#include<iostream>#include<fstream>#include<array>#defineN5intmain(){usingnamespacestd;array<int,N>x{97,98,99,100,101......
  • 无线传感器网络技术-实验一-TINYOS/6LOWPAN 编程基础
    【实验目的】1.掌握TinyOS/6LoWPAN开发环境的搭建方法2.掌握VisualStudioCode中TinyOS编程的相关设置3.掌握VSCode中CC2530节点(平台名称cc2530zn)和CC......