| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 567 人关注过本帖
标题:[求助]本人是鹤群中的一只小鸡!求高手帮偶编个程序!!
只看楼主 加入收藏
xjjxjj12345
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2005-12-18
收藏
 问题点数:0 回复次数:3 
[求助]本人是鹤群中的一只小鸡!求高手帮偶编个程序!!

标准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
4. 需要考虑程序的稳定性(各种错误处理)及健壮性(算法是否对所有的整数都适用),
不能有内存泄漏。

搜索更多相关主题的帖子: 鹤群 小鸡 
2005-12-21 20:40
xjjxjj12345
Rank: 1
等 级:新手上路
帖 子:20
专家分:0
注 册:2005-12-18
收藏
得分:0 
怎么没人理我啊?

2005-12-25 10:58
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 20:53
nothingcan
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2005-12-31
收藏
得分:0 

居然把交大的第就次作业贴出来了,够狠的..

2005-12-31 23:35
快速回复:[求助]本人是鹤群中的一只小鸡!求高手帮偶编个程序!!
数据加载中...
 
   



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

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