B. 向量2(友元及拷贝构造)

题目描述

在题目向量1的代码上添加类CVector的友元函数add,计算两个向量的和(对应分量相加)。

add定义如下:

CVector add(const CVector v1, const CVector v2)  //函数头不可修改。

主函数输入数据,生成两个向量对象v1,v2,调用add(v1, v2).print()输出向量v1 + v2的计算结果。(假设print()为CVector类中的输出函数。)

可根据需要,为类CVector添加拷贝构造函数及其它成员函数。


输入

第一行,输入测试次数t

每组测试数据格式如下:

向量维数n

第一个n维向量值

第二个n维向量值

 


输出

对每组测试数据,输出两个n维向量与它们的和


输入样例1 
2
3
1 2 3
4 5 6
5
1 2 3 4 5
-1 2 4 6 10

输出样例1
1 2 3
4 5 6
5 7 9
1 2 3 4 5
-1 2 4 6 10
0 4 7 10 15

该题主要考察友元函数的使用 

#include<iostream>
using namespace std;
class cvector
{
private:
    int* data;
    int n;
public:
    friend cvector add(const cvector v1, const cvector v2);
    cvector() { ; }
    cvector(int n1, int* a)
    {
        n = n1;
        data = new int[n];
        for (int i = 0; i < n1; i++)
        {
            data[i] = a[i];
        }
    }
    //~cvector() { delete[]data; }
    void print();

};


cvector add(const cvector v1, const cvector v2)
{
    int sum=v1.n;
    int num[100];
    for (int i = 0; i < sum; i++)
    {
        num[i] = v1.data[i] + v2.data[i];
    }
    cvector c(sum, num);
    return c;
}
void cvector::print()
{
    cout << data[0];
    for (int i = 1; i < n; i++)
    {
        cout << ' ' << data[i];
    }
    cout << endl;
}

int main()
{
    int t,n;
    cin >> t;
    while (t--)
    {
        cin >> n;
        int* num1 = new int[n];
        int* num2 = new int[n];
        for (int i = 0; i < n; i++)
        {
            cin >> num1[i];
        }
        for (int i = 0; i < n; i++)
        {
            cin >> num2[i];
        }
        cvector a(n, num1);
        cvector b(n, num2);
        a.print();
        b.print();
        cvector c = add(a, b);
        c.print();
        delete[]num1;
        delete[]num2;
    }
    return 0;
}

向量类(综合型题目) (1)创建C# 控制台应用程序L4_2。 (2)在程序中创建一个向量类CzVector,在其中定义一个double []类型的私有字段_values,用于维护向量的各个元素值。 (3)为CzVector定义三个公有属性Length、Sum和Prod,分别用于返回向量的长度、向量所有元素的和以及向量所有元素的积。 (4)在CzVector中定义一个索引函数,用于获取或设置各个元素的值。 (5)为CzVector定义两个构造函数,一个根据指定长度对向量进行初始化(向量各元素取默认值0),另一个由指定的数组来构造向量并设置各元素的值。 (6)利用操作符重载来实现向量加法、减法和乘法。这三种运算均要求两个向量的长度相等。设向量α=(a1,a2,…an) ,β=(b1,b2,…bn),那么α+β=(a1+b1,a2+b2,….,an+bn),减法与之类似,而α*β=a1*b1+a2*b2+….+an*bn)。另外,一个向量还可以单独乘以一个系数(向量加法的重载形式),此时,λ*α=(λ*a1, λ*a2,…λ*an) 。以加法操作符重载为例,参考源代码如下: public static CzVector operator +(CzVector v1,CzVector v2) { if(v1.Length!=v2.Length) return null; CzVector result=new CzVector(v1.Length); for(int i=0;i<v1.Length;i++) result [i]=v1[i]+v2[i]; return result; } (7)类似的,利用操作符重载来判断两个向量是否相等。向量相等的条件是:两个向量的长度相等,且各个位置上的对应元素值也相等。 (8)为CzVector定义一个ConsoleOutput方法,用于在控制台一行输出向量的所有元素,其之间以空格分割。 (9)在程序主方法中随机定义几个向量对象,并测试其运算结果。参考源代码如下: static void Main() { CzVector v1=new CzVector(1,-5,9,6); CzVector v2=new CzVector(0,1,2,3); Console.Write(“v1= “); v1.ConsoleOutput(); Console.Write(“v2= “); v2.ConsoleOutput(); CzVector v3=v1+v2; Console.Write(“v1+v2= “); v3.ConsoleOutput(); CzVector v4=v1-v2; Console.Write(“v1-v2= “); v4.ConsoleOutput(); Console.Write(“3*(v1+v2)= “); (v3*3).ConsoleOutput(); Console.Write(“v1*v2= “{0}”,v1*v2); }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ZZZWWWFFF_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值