| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 770 人关注过本帖
标题:一道很不错的程序题,求高手帮忙解决!
只看楼主 加入收藏
xjjxjj12345
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2005-12-18
收藏
 问题点数:0 回复次数:6 
一道很不错的程序题,求高手帮忙解决!
题目的主要部分如下:

说明部分:

标准C++的内部数据类型int在Win32平台下占用4个字节存储数据(sizeof(int) = 4),其能够表达的整数范围为:-2147483648 — 2147483647 (-2^15 — 2^15-1)。

以下为要求部分:

请设计出一个新的数据类型(class MyInt),使其能够完成任意整数间的基本运算。
并再设计一个新的数据类型(class ComplexInt),使其能够完成任意复数(限制条件:
复数的实部和虚部都均为整数)之间的基本运算。

1. 定义一个新类(class MyInt),使其能够实现任意位整数间的加法和减法。
2. 定义一个新类(class ComplexInt),用于实现任意复数(限制条件:复数的实部和
虚部都均为整数)间的加法和减法。
3. 能够通过类似于如下的语句,并在屏幕上输出正确的结果。

void main(int argc, char* argv[])
{
MyInt iM("1234567890123"); // 整数对象初始化
MyInt iN("-3210987654321");
MyInt iResult1;
iResult1 = iM;
iResult1 += iN; // 整数加法操作
MyInt iResult2 = iM;
iResult2 -= iN; // 整数减法操作
// 结果输出
Display(iResult1); // iResult1: -1976419764198
Display(iResult2); // iResult2: 4445555544444

// 实部: 1234567890123;虚部: 4445555544444
ComplexInt ciM("1234567890123", "4445555544444"); // 复数对象初始化
// 实部: -4445555544444;虚部: 0
ComplexInt ciN("-4445555544444"); // 复数对象初始化
ComplexInt ciResult1 = ciM;
ComplexInt ciResult2 = ciM;
ciResult1 += ciN; // 复数加法操作
ciResult2 -= ciN; // 复数减法操作
// 结果输出
Display(ciResult1);
Display(ciResult2);
}

其中,Display为一个全局函数,它可以根据所代入的参数类型进行相应的结果输
出(代入的参数是MyInt,则输出相应的整数;代入的是ComplexInt,则输出相应复
数的实部和虚部)。

得到的屏幕输出应该为:

This is MyInt::Display, the result is: -1976419764198
This is MyInt::Display, the result is: 4445555544444
This is ComplexInt::Display, the result is: -3210987654321 + 4445555544444 i
This is ComplexInt::Display, the result is: 5680123434567 + 4445555544444 i

另外,我的邮箱:xxjjjjabba@yahoo.com.cn
QQ:513068894

先谢谢大家了!!

搜索更多相关主题的帖子: 整数 STRONG 
2005-12-22 19:51
dlcdavid
Rank: 3Rank: 3
来 自:成都
等 级:新手上路
威 望:6
帖 子:193
专家分:0
注 册:2005-12-23
收藏
得分:0 
看不懂,呵呵

为了C++,我放弃了课本
为了高考,我又放弃了C++
现在而今眼目下,我能做什么?www.
2005-12-23 17:46
corrupt
Rank: 2
等 级:新手上路
威 望:3
帖 子:535
专家分:0
注 册:2004-9-29
收藏
得分:0 
1. 定义一个新类(class MyInt),使其能够实现任意位整数间的加法和减法。
2. 定义一个新类(class ComplexInt),用于实现任意复数(限制条件:复数的实部和
虚部都均为整数)间的加法和减法。
-------------------------------------------
还好,自己 去试试吧..

第二个重载会多些

2005-12-25 08:51
xjjxjj12345
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2005-12-18
收藏
得分:0 
本人也是新手啊,谁能帮帮偶啊?

2005-12-25 10:57
corrupt
Rank: 2
等 级:新手上路
威 望:3
帖 子:535
专家分:0
注 册:2004-9-29
收藏
得分:0 

楼上的 你想要吗??
那我回去 写好了 发上来啊`


2005-12-25 11:11
corrupt
Rank: 2
等 级:新手上路
威 望:3
帖 子:535
专家分:0
注 册:2004-9-29
收藏
得分:0 

时间紧,写的不好,不要见怪啊~~

头文件 :myint.h
---------------------------
#ifndef _MYINT_H
#define _MYINT_H

#include<iostream>
#include<string>

using namespace std;

const int MAX=20;

class MyInt
{
private:
int arry[MAX];
int plus;
int size;
protected:
int bigger(const MyInt & lhs)
{
if(size>lhs.size)
return 1;
else if(size<lhs.size)
return 0; //lhs bigger
else if(size=lhs.size)
{
for(int i=size-1;i>=0;i--)
{
if(arry[i]>lhs.arry[i])
return 1;
else if(arry[i]<lhs.arry[i])
return 0;
}

}
return 0;
}
void add(const MyInt &lhs,int pp)
{
int pp_plus=lhs.plus;
if(pp==1)
pp_plus=(pp_plus+1)%2;

int temp=0;
//-----------------
if(plus==0&&pp_plus==0)
{
for(int i=0;i<MAX;i++)
{ temp=arry[i]+lhs.arry[i];
if(temp>9)
{
temp=temp-10;
arry[i+1]=arry[i+1]+1;
}
arry[i]=temp;
}
}
//--------------------
if(plus==0&&pp_plus==1)
{
if(bigger(lhs)==1)
{
for(int i=0;i<MAX;i++)
{
temp=arry[i]-lhs.arry[i];
if(temp<0)
{
temp=temp+10;
arry[i+1]=arry[i+1]-1;
}
arry[i]=temp;
}
}
else
{
int swap[MAX];
for(int i=0;i<MAX;i++)
swap[i]=arry[i];
for(i=0;i<MAX;i++)
arry[i]=lhs.arry[i];

for( i=0;i<MAX;i++)
{
temp=arry[i]-swap[i];
if(temp<0)
{
temp=temp+10;
arry[i+1]=arry[i+1]-1;
}
arry[i]=temp;
}
}
}
//-------------------------
if(plus==1&&pp_plus==1)
{
for(int i=0;i<MAX;i++)
{ temp=arry[i]+lhs.arry[i];
if(temp>9)
{
temp=temp-10;
arry[i+1]=arry[i+1]+1;
}
arry[i]=temp;
}
}
//-------------------
if(plus==1&&pp_plus==0)
{
if(bigger(lhs)==1)
{
for(int i=0;i<MAX;i++)
{
temp=arry[i]-lhs.arry[i];
if(temp<0)
{
temp=temp+10;
arry[i+1]=arry[i+1]-1;
}
arry[i]=temp;
}
}
else
{
int swap[MAX];
for(int i=0;i<MAX;i++)
swap[i]=arry[i];
for(i=0;i<MAX;i++)
arry[i]=lhs.arry[i];

for( i=0;i<MAX;i++)
{
temp=arry[i]-swap[i];
if(temp<0)
{
temp=temp+10;
arry[i+1]=arry[i+1]-1;
}
arry[i]=temp;
}
}
}

}

public:
MyInt() : plus(0),size(0) {
for(int i=0;i<MAX;i++)
arry[i]=0;
}
MyInt(string str)
{
int temp=0;
for(int i=0;i<MAX;i++)
arry[i]=0;
if(str[0]=='-')
{ plus=1;
size=str.size()-1;
for(i=str.size()-1;i>0;i--)
{ temp=int(str[i])-48;
arry[size-i]=temp;
}
}
else
{ plus=0;
size=str.size();
for(i=str.size()-1;i>=0;i--)
{ temp=int(str[i])-48;
arry[size-1-i]=temp;
}
}
}
void operator =(const MyInt &lhs)
{
plus=lhs.plus;
size=lhs.size;
for(int i=0;i<MAX;i++)
{ arry[i]=0;
arry[i]=lhs.arry[i];
}
}
void operator +=( const MyInt &lhs)
{
add(lhs,0);
}
void operator -=(const MyInt &lhs)
{

add(lhs,1);
}
void display()
{

if(plus==1)
cout<<"-";
int flag=0;
for (int i=MAX-1;i>=0;i--)
{

if(arry[i]!=0||flag==1)
{
flag=1;
if(flag==1)
cout<<arry[i];
}
}

}
};
#endif
//----------
头文件 complex.h

#ifndef _COMPLEX_H
#define _COMPLEX_H

#include"myint.h"
class ComplexInt
{
private:
MyInt real;
MyInt unreal;
public:
ComplexInt() : real("0"),unreal("0"){}
ComplexInt(string r,string ur) :real(r),unreal(ur) {}
ComplexInt(string r) :real(r),unreal("0") {}


void operator +=(const ComplexInt & lhs)
{
real+=lhs.real;
unreal+=lhs.unreal;
}
void operator -=(const ComplexInt & lhs)
{
real-=lhs.real;
unreal-=lhs.unreal;
}
void operator =(const ComplexInt & lhs)
{
real=lhs.real;
unreal=lhs.unreal;
}
void display()
{
real.display();
cout<<"+";
unreal.display();
cout<<"i";
}
};
#endif
主函数:main.cpp

#include "complex.h"
#include "myint.h"

void Display(MyInt myint)
{
cout<<"This is MyInt::Display, the result is: ";
myint.display();
cout<<endl;
}
void Display(ComplexInt complex )
{
cout<<"This is ComplexInt::Display, the result is: ";
complex.display();
cout<<endl;
}
void main(int argc, char* argv[])
{
MyInt iM("1234567890123"); // 整数对象初始化
MyInt iN("-4445555544444");
MyInt iResult1;
iResult1 = iM;
iResult1 += iN; // 整数加法操作
MyInt iResult2 = iM;
iResult2 -= iN; // 整数减法操作
// 结果输出
Display(iResult1); // iResult1: -1976419764198
Display(iResult2); // iResult2: 4445555544444
// 实部: 1234567890123;虚部: 4445555544444
ComplexInt ciM("1234567890123", "4445555544444"); // 复数对象初始化
// 实部: -4445555544444;虚部: 0
ComplexInt ciN("-4445555544444"); // 复数对象初始化
ComplexInt ciResult1 = ciM;
ComplexInt ciResult2 = ciM;
ciResult1 += ciN; // 复数加法操作
ciResult2 -= ciN; // 复数减法操作
// 结果输出
Display(ciResult1);
Display(ciResult2);
}


2005-12-25 16:38
xjjxjj12345
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2005-12-18
收藏
得分:0 
先谢谢这位大哥啦!
写的也挺好啊,至少我是写不出这样的程序来,还有最好能用到友元函数就好了

2005-12-25 21:33
快速回复:一道很不错的程序题,求高手帮忙解决!
数据加载中...
 
   



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

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