标题:新手C++求助,此程序有点错误求,高手帮忙改下或者帮忙写个,小弟在这感激不尽 ...
只看楼主
chenbccn
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2013-6-26
结帖率:100%
已结贴  问题点数:16 回复次数:8 
新手C++求助,此程序有点错误求,高手帮忙改下或者帮忙写个,小弟在这感激不尽啊...
题目要求:
       用c++建立一个二维坐标系的类TwoCoor,用x、y表示坐标值,实现两坐标点的加、减运算,计算两坐标点间的距离,并重载输入/输出运算符,使之能够直接输入/输出坐标点的坐标值.
运行环境VC6.0或CodeBlocks
下面是我在网上找的代码,有几个错误,但不会修改.......
程序代码:
#include<iostream>
#include<cmath>
using namespace std;
class TwoCoor
{
private:
    double x,y;
public:
    TwoCoor(double X=0,double Y=0):x(X),y(Y) {};
    friend TwoCoor operator+(TwoCoor p1,TwoCoor p2);
    friend TwoCoor operator-(TwoCoor p1,TwoCoor p2);
    friend       double  dist(TwoCoor p1,TwoCoor p2);
    friend TwoCoor &operator<<(ostream &os,TwoCoor &t);
    friend TwoCoor &operator>>(istream &is,TwoCoor &t);
};
TwoCoor operator+(TwoCoor p1,TwoCoor p2)
{
    return TwoCoor(p1.x+p2.x,p1.y+p2.y);
}
TwoCoor operator-(TwoCoor p1,TwoCoor p2)
{
    return TwoCoor(p1.x-p2.x,p1.y-p2.y);
}
double  dist(TwoCoor p1,TwoCoor p2)
{
    double x=(p1.x-p2.x);
    double y=(p1.y-p1.y);
    return sqrt(x*x+y*y);
}
TwoCoor &operator<<(ostream &os,TwoCoor &t)
{
    os<<"\t"<<t.x<<"\t";
    os<<t.y<<endl;
    return t;
}
TwoCoor &operator>>(istream &is,TwoCoor &t)
{
    cout<<"坐标点的横坐标:";
    is>>t.x;
    cout<<"坐标点的纵坐标:";
    is>>t.y;
    return t;
}
int main()
{
    TwoCoor t1,t2;
    char select;
    while(1)
    {
        cout<<"------------------坐标点计算系统-----------------------"<<endl;
        cout<<"         0            计算两坐标点对应坐标之和         "<<endl;
        cout<<"         1            计算两坐标点对应坐标之差         "<<endl;
        cout<<"         2            计算两坐标点的距离               "<<endl;
        cout<<"         3            退出系统                         "<<endl;
        cout<<"*******************************************************"<<endl;
        cout<<"请输入你的选择:";
        cin>>select;
        if(select=='0')
        {
            cout<<"请输入坐标点1的坐标:"<<endl;
            cin>>t1;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"点1";
            cout<<t1;
            cout<<"---------------------------------------"<<endl;
            cout<<"请输入坐标点2的坐标:"<<endl;
            cin>>t2;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"点2";
            cout<<t2;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"\t"<<"\t"<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"两坐标点的对应坐标相加为:"<<operator+(t1,t2);
        }
        else if(select=='1')
        {
            cout<<"请输入坐标点1的坐标:"<<endl;
            cin>>t1;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"点1";
            cout<<t1;
            cout<<"---------------------------------------"<<endl;
            cout<<"请输入坐标点2的坐标:"<<endl;
            cin>>t2;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"点2";
            cout<<t2;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"\t"<<"\t"<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"两坐标点的对应坐标相减为:"<<operator-(t1,t2);
        }
        else if(select=='2')
        {
            cout<<"请输入坐标点1的坐标:"<<endl;
            cin>>t1;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"点1";
            cout<<t1;
            cout<<"---------------------------------------"<<endl;
            cout<<"请输入坐标点2的坐标:"<<endl;
            cin>>t2;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"点2";
            cout<<t2;
            cout<<"---------------------------------------"<<endl;
            cout<<"两坐标点的距离为:"<<dist(t1,t2)<<endl;
        }
        else if(select=='3')
            exit(0);
        else
        {
            cout<<"输入错误,请重新输入"<<endl;
            continue;
        }

    }
}


求哪位好心人帮忙改一下,或者帮忙写一个,小弟在这感激不尽啊.......
水贴的就不要来了。。。。。。。
搜索更多相关主题的帖子: 运行环境 坐标系 网上 
2013-06-29 22:33
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
得分:0 
自己写一个嘛,干嘛网上抄,这个不难

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-06-30 07:29
chenbccn
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2013-6-26
得分:0 
回复 2楼 peach5460
你又来水贴了........
2013-06-30 08:30
我有我梦
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:1
帖 子:321
专家分:1128
注 册:2013-5-25
得分:0 
自己写一个嘛,干嘛网上抄,这个不难

这个建议很好啊!!
2013-06-30 10:17
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
得分:0 
以下是引用chenbccn在2013-6-30 08:30:00的发言:

你又来水贴了........

如果说你要饭的时候,我路过了没有给你丢钱,你就心生怨恨,我无话可说...

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-06-30 10:59
fengshan。
Rank: 2
等 级:论坛游民
帖 子:7
专家分:16
注 册:2013-4-6
得分:16 
程序代码:
#include <iostream>
#include <cmath>
#include <cstdlib>

using namespace std ;

class TwoCoor
{
private:
    double x, y ;
public:
    TwoCoor()
    { }
    TwoCoor(double x1,double y1)
    {
        x = x1 ;    y = y1 ;
    }
    friend TwoCoor operator+ (TwoCoor a,TwoCoor b)
    {
        return TwoCoor(a.x+b.x,a.y+b.y);
    }
    friend TwoCoor operator-(TwoCoor a,TwoCoor b)
    {
        return TwoCoor(a.x-b.x,a.y-b.y);
    }
    friend double  dist(TwoCoor a,TwoCoor b)
    {
        return sqrt((a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y));
    }
    friend ostream & operator<<(ostream &cout,const TwoCoor &a)
    {
        cout<<"( "<<a.x<<" , "<<a.y<<" )"<<endl;
        return cout;
    }
    friend istream & operator>>(istream &cin, TwoCoor &a)
    {
        cin>>a.x>>a.y;
        return cin;
    }
};

int main()
{
    TwoCoor t1,t2;
    char select;
    while(1)
    {
        system ( "cls" );
        cout<<"------------------坐标点计算系统-----------------------"<<endl;
        cout<<"         0            计算两坐标点对应坐标之和         "<<endl;
        cout<<"         1            计算两坐标点对应坐标之差         "<<endl;
        cout<<"         2            计算两坐标点的距离               "<<endl;
        cout<<"         3            退出系统                         "<<endl;
        cout<<"*******************************************************"<<endl;
        cout<<"请输入你的选择:";
        cin>>select;
        if(select=='0')
        {
            cout<<"请输入坐标点1的坐标:"<<endl;
            cin>>t1;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"点1";
            cout<<t1;
            cout<<"---------------------------------------"<<endl;
            cout<<"请输入坐标点2的坐标:"<<endl;
            cin>>t2;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"点2";
            cout<<t2;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"\t"<<"\t"<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"两坐标点的对应坐标相加为:"<<operator+(t1,t2);
            system("pause") ;
        }
        else if(select=='1')
        {
            cout<<"请输入坐标点1的坐标:"<<endl;
            cin>>t1;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"点1";
            cout<<t1;
            cout<<"---------------------------------------"<<endl;
            cout<<"请输入坐标点2的坐标:"<<endl;
            cin>>t2;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"点2";
            cout<<t2;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"\t"<<"\t"<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"两坐标点的对应坐标相减为:"<<operator-(t1,t2);
            system("pause") ;
        }
        else if(select=='2')
        {
            cout<<"请输入坐标点1的坐标:"<<endl;
            cin>>t1;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"点1";
            cout<<t1;
            cout<<"---------------------------------------"<<endl;
            cout<<"请输入坐标点2的坐标:"<<endl;
            cin>>t2;
            cout<<"---------------------------------------"<<endl;
            cout<<"\t"<<"横坐标"<<"\t"<<"纵坐标"<<endl;
            cout<<"点2";
            cout<<t2;
            cout<<"---------------------------------------"<<endl;
            cout<<"两坐标点的距离为:"<<dist(t1,t2)<<endl;
            system("pause") ;
        }
        else if(select=='3')
            break ;
        else
        {
            cout<<"输入错误,请重新输入"<<endl;
            continue;
        }

    }
    return 0;
}


os那儿没加const 好像过了那一块儿就完了

我不能忍受烂的排版!!绝壁不能忍!!
2013-06-30 15:06
chenbccn
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2013-6-26
得分:0 
回复 5楼 peach5460
下面是我上次发帖时他来水,我回复的
回复 3楼 peach5460
不知者无罪,作为新人第一次发帖,难免出错,而你身为资深版主却不依不饶,我只能说国人的道德因你倒退了20年
上次帖子的地址:https://bbs.bccn.net/thread-416118-1-1.html
虽然我初次来次论坛,但不能不说peach5460就是水贴的,,
阿弥陀佛,罪过罪过,我不想骂人,所以请你peach5460注意一下你的言行!!!!!
2013-06-30 22:18
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
得分:0 
你自己也说了,这个题目,你是在网上找的代码...
而且你只是想求个答案...

我承认我言辞过激,因为我讨厌不劳而获的人...
你只是想要答案,而不是想学编程...
我承认我只是想快点把你赶出去,因为你又不想学,在你身上完全是浪费时间...

新人发帖不是一块挡箭牌,谢谢...
我并不是说看到你帖子里面的编程技术多么匮乏,看到你多么无知所以歧视你...
大家都是从菜鸟过来的...
我只是觉得你的学习态度有问题...
我关注的是态度,不是你的知识量,谢谢...

而且,这个题目,我估量过,不是很难,只是一些类和继承的基本概念...
我的回复我认为没有错,我叫你自己尝试写一下...
结果你非但不想自己写,还觉得我不跟你写就是水贴...苦口婆心啊,姐姐...
我承认有的帖子我是水过,但是你这个,你让大家自己说吧...

关于这个问题,我不再作回复...拜...

[ 本帖最后由 peach5460 于 2013-7-1 08:30 编辑 ]

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-07-01 08:26
chenbccn
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2013-6-26
得分:0 
回复 8楼 peach5460
如你所愿,此论坛,我将永久退出,别的我也不多说了。。。。。。
2013-07-03 13:28



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-416369-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.195946 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved