江苏科技大学
课程实践报告
设计题目: 程序设计(VC++)实践
设计时间至
学院(系):
专业班级:
学生姓名:学号
指导老师:
2013年12月
任务一
一、实践任务
2.试建立一个类SP,求,另有辅助函数power(m,n)用于求。
二、详细设计
1、类的描述与定义
(1)私有数据成员
● int n,k:存放公式中n和k的值;
(2)公有成员函数
● SP(int n1,int k1):构造函数,初始化成员数据n和k。
● int power(int m, int n):求m n。
● int fun( ):求公式的累加和。
● void show( ):输出求得的结果。
2、主要函数设计
在主程序中定义对象s,对该类进行测试。
三、源程序清单
#include
class SP
{
int n,k;
public:
SP(int n1,int k1)
{
n=n1;k=k1;
}
int power(int m,int n)
{
int p=1;
for (int i=1;i p*=m; return p; } int fun() { int s=0; for (int i=1;i s+=power(i,k); return s; } void A() { cout<<"n="< } }; void main() { SP a(3,3); a.power(3,3); a.fun(); a.A(); }四、实践小结 掌握用循环语句求m^n,和m!,熟练掌握函数的调用。 五、运行结果 任务三 一、实践任务 3.建立一个类MOVE,不进行排序,将数组中小于平均值的元素放到数组的左边,大于平均值的元素放到数组的右边。 二、详细设计 1、类的描述与定义 (1)私有数据成员 ● float array[20]:一维整型数组。 ● int n:数组中元素的个数。 (2)公有成员函数 ● MOVE(float b[],int m):构造函数,初始化成员数据。 ● void average():输出平均值,并将数组中的元素按要求重新放置。 ● void print():输出一维数组。 2、主要函数设计 在主程序中用数据{1.3,6.2,3,9.1,4.8,7.4,5.6,9.2,2.3}对该类进行测试。 三、源程序清单 四、实践小结 应熟练掌握数组与指针的应用。 五、运行结果 任务四 一、实践任务 4.建立一个类MOVE,将数组中最大元素的值与最小元素的值互换。 二、详细设计 1、类的描述与定义 (1)私有数据成员 ● int *array:一维整型数组。 ● int n:数组中元素的个数。 (2)公有成员函数 ● MOVE(int b[],int m):构造函数,初始化成员数据。 ● void exchange():输出平均值,并将数组中的元素按要求重新放置。 ● void print():输出一维数组。 ● ~MOVE():析构函数。 2、主要函数设计 在主程序中用数据{21,65,43,87,12,84,44,97,32,55}对该类进行测试。 三、源程序清单 四、实践小结 学会求数组中最大元素与最小元素方法,并实现交换。 五、运行结果 任务六 一、实践任务 6.定义一个字符串类String,实现判断该字符串是否为回文字符串。所谓回文字符串,是指该字符串左右对称。例如字符串“123321”是回文字符串。 二、详细设计 1、类的描述与定义 (1)私有数据成员 ● char *str; ● int y:标记是否为回文字符串。 (2)公有成员函数 ● String (char *s) :构造函数,用给定的参数s初始化数据成员str。y初始化 为0。 ● void huiwen () :判断str所指向的字符串是否为回文字符串。 ● void show( ) :在屏幕上显示字符串。 2、主要函数设计 在主程序中定义字符串char s[]=”ababcedbaba”作为原始字符串。定义一个String类对象test,用s初始化test,完成对该类的测试。 三、源程序清单 四、实践小结 掌握判断回文字符串的一般形式。 五、运行结果 任务十一 一、实践任务 11.建立一个STRING,将一个字符串交叉插入到另一个字符串中(假定两字符串等长)。 例如将字符串“abcde” 交叉插入字符串“ABCDE”的结果为“aAbBcCdDeE”或“AaBbCcDdEe”。 二、详细设计 1、类的描述与定义 (1)私有数据成员 ● char str1[80] :存放被插入的字符串。 ● char str2[40] :存放待插入的字符串。 (2)公有成员函数 ● STRING (char *s1, char *s2 ):构造函数,用s1和s2初始化str1和str2。 ● void process():将str2中的字符串插入到str1中。 void print():输出插入后的字符串。 2、主要函数设计 在主程序中定义STRING类的对象test对该类进行测试。 三、源程序清单 #include #include class STRING{ private: c har str1[80];//存放被插入的字符串; c har str2[40];//存放待插入的字符串; public: S TRING(char*s1,char*s2) { strcpy(str1,s1); strcpy(str2,s2); } v oid process(); v oid print(); }; void STRING::process() { i nt i,j; i nt n=strlen(str1); i f(strlen(str2)>strlen(str1)) {//当待插入的字符串ABCDEFG比被插入的字符串abcde长或相等时,逻辑算法:abcde->a b c d e->空格处依次插入ABCDEFG->aAbBcCdDeEFG; for(i=n-1;i>0;i--) { str1[i+i]=str1[i];//被插入的字符串由最后一位开始各位向后移动i位; } for(i=1,j=0;i<2*n;i+=2,j++) { str1[i]=str2[j];//在空出的位置处依次插入字符串; } i--; for(;j<=strlen(str2);j++,i++) { str1[i]=str2[j];//将过长额字符串放入被插入的字符串尾部,完成插入; } } e lse//当待插入的字符串abcde比被插入的字符串ABCDEFG短时,逻辑算法:ABCDEFG->A B C D E FG->空格处插入abcde->AaBbCcDdEeFG; { for(i=n;i>strlen(str2)-1;i--) { str1[i+strlen(str2)]=str1[i];//比待插入的字符串长的部分均向后移strlen(str2)位; } for(i=strlen(str2)-1;i>0;i--) { str1[i+i]=str1[i];//之前的部分均向后移i位; } for(i=1,j=0;i<2*strlen(str2);i+=2,j++) { str1[i]=str2[j];//将待插入的字符串插入空格处,完成插入; } } } void STRING::print()//输出插入后的字符串 { c out<<"插入后的字符串为:"< } void main()//测试 { S TRING test("ABCDE","abcde"); t est.process(); t est.print(); } 四、实践小结 发现字符插入的规律,再依次放入相应字符位置。 五、运行结果 任务十二 一、实践任务 12.建立一个STRING,将一个字符串交叉插入到另一个字符串中(假定两字符串不等长)。 例如将字符串“abcde” 交叉插入字符串“ABCDEFG”的结果为“aAbBcCdDeEFG”或“AaBbCcDdEeFG”。 二、详细设计 1、类的描述与定义 (1)私有数据成员 ● char str1[60] :存放被插入的字符串。 ● char str2[40] :存放待插入的字符串。 ● char str3[100] :存放插入后的字符串。 (2)公有成员函数 ● STRING (char *s1, char *s2 ):构造函数,用s1和s2初始化str1和str2。 ● void process():将str2中的字符串插入到str1中,存放到str3中。 ● void print():输出插入后的字符串。 2、主要函数设计 在主程序中定义STRING类的对象test对该类进行测试。 三、源程序清单 #include #include class STRING{ private: c har str1[60]; c har str2[40]; c har str3[100]; public: S TRING(char*s1,char*s2) { strcpy(str1,s1); strcpy(str2,s2); } v oid process(); v oid print(); }; void STRING::process() { i nt i,j; i nt n=strlen(str1); i f(strlen(str2)>strlen(str1)) {//当待插入的字符串ABCDEFG比被插入的字符串abcde长或相等时,逻辑算法:abcde->a b c d e->空格处依次插入ABCDEFG->aAbBcCdDeEFG; for(i=n-1;i>0;i--) { str1[i+i]=str1[i];//被插入的字符串由最后一位开始各位向后移动i位; } for(i=1,j=0;i<2*n;i+=2,j++) { str1[i]=str2[j];//在空出的位置处依次插入字符串; } i--; for(;j<=strlen(str2);j++,i++) { str1[i]=str2[j];//将过长额字符串放入被插入的字符串尾部,完成插入; } } e lse//当待插入的字符串abcde比被插入的字符串ABCDEFG短时,逻辑算法:ABCDEFG->A B C D E FG->空格处插入abcde->AaBbCcDdEeFG; { for(i=n;i>strlen(str2)-1;i--) { str1[i+strlen(str2)]=str1[i];//比待插入的字符串长的部分均向后移strlen(str2)位; } for(i=strlen(str2)-1;i>0;i--) { str1[i+i]=str1[i];//之前的部分均向后移i位; } for(i=1,j=0;i<2*strlen(str2);i+=2,j++) { str1[i]=str2[j];//将待插入的字符串插入空格处,完成插入; } } s trcpy(str3,str1);//将str2中的字符串插入到str1中,存放到str3中; } void STRING::print()//输出插入后的字符串 { c out<<"插入后的字符串为:"< } void main() { S TRING test("abcde","ABCDEFG"); t est.process(); t est.print(); } 四、实践小结 发现字符插入的规律,再依次放入相应字符位置。 五、运行结果 任务十三 一、实践任务 13.建立一个类MOVE,对数组中元素进行循环换位,即每个元素后移三位,最后三个元素移到最前面。 二、详细设计 1、类的描述与定义 (1)私有数据成员 ● int array[20]:一维整型数组。 ● int n:数组中元素的个数。 (2)公有成员函数 ● MOVE(int b[],int m):构造函数,初始化成员数据。 ● void change():进行循环换位。 ● void print():输出一维数组。 2、主要函数设计 在主程序中用数据{21,65,43,87,12,84,44,97,32,55}对该类进行测试。 三、源程序清单 #include class MOVE{ private: i nt array[20];//一维整型数组; i nt n; //数组中的元素个数; public: M OVE(int b[],int m) { for(int i=0;i array[i]=b[i]; n=m; } v oid change(); v oid print(); }; void MOVE::change()//进行循环换位,即每个元素后移3位,最后3个元素移到最前面; { i nt tem[3];//建立临时数组,用于存放最后3个元素; i nt i=0; w hile(i<3) { tem[2-i]=array[n-1-i];//将最后3个元素依次放入临时数组中; i++; } f or(i=0;i { array[n-1-i]=array[n-1-3-i]; } f or(i=0;i<3;i++)//将临时数组中存放的最后3个元素依次放入后移后的原数组中,完成循环换位; { array[i]=tem[i]; } } void MOVE::print()//输出一维数组; { f or(int i=0;i cout< c out< } void main() { i nt s[]={21,65,43,87,12,84,44,97,32,55}; i nt n=sizeof(s)/sizeof(int); M OVE test(s,n); t est.print(); t est.change(); t est.print(); } 四、实践小结 利用临时数组先保存后3位,再依次把数放入对应位。 五、运行结果 任务十四 一、实践任务 14.建立一个类MOVE,实现将数组中大字字母元素放在小写字母元素的左边。 二、详细设计 1、类的描述与定义 (1)私有数据成员 ● char *array:一维字符数组。 ● int n:数组中元素的个数。 (2)公有成员函数 ● MOVE(char b[],int m):构造函数,初始化成员数据。 ● void change():进行排序换位。 ● void print():输出一维数组。 ● ~MOVE():析构函数。 2、主要函数设计 在主程序中用数据"fdsUFfsTjfsKFEkWC"对该类进行测试。三、源程序清单 #include #include class MOVE{ char *array; int n; public: MOVE(char b[],int m) { n=m; array=new char[n+1]; strcpy(array,b); } void change() { char*p1=new char[strlen(array)+1];//用于存大写; char*p2=new char[strlen(array)+1];//存小写; int i,j=0,k=0; for(i=0;i { if(array[i]>='A'&&array[i]<='Z') { p1[j]=array[i]; j++; } else {p2[k]=array[i];k++;} } p1[j]=p2[k]='\0'; strcat(p1,p2);//存放大写组与小写组拼接; strcpy(array,p1);//拷贝至array; delete []p1; delete []p2; } void print() { cout< } ~MOVE() { if (array) delete []array; } }; void main() { char b[]="fdsUFfsTjfsKFEkWC"; int n; n=(sizeof(b)-1)/sizeof(char); MOVE test(b,n); test.change(); test.print(); } 四、实践小结 利用临时数组,分别保存大写与小写字母,再实现功能。 五、运行结果 任务十五 一、实践任务 16.定义一个方阵类CMatrix,并根据给定算法实现方阵的线性变换。方阵的变换形式为:F=W*f T f为原始矩阵,f T为原始矩阵的转置,w为变换矩阵,这里设定为 1 0 0 1 0 1 1 0 0 1 1 0 1 0 0 1 二、详细设计 1、类的描述与定义 (1)私有数据成员 ● int (*a)[4]:a指向方阵数组。 ● int w[4][4]:w为变换矩阵。 ● int m:m表示方阵的行和列数。 (2)公有成员函数 ● CMatrix (int a[][4],int m) :用给定的参数a和m 初始化数据成员a和m;对变 换矩阵w进行初始化,要求必须用循环实现。 ● void Transform () :根据上述变换算法,求出变换后的数组形式,存放在原始数 组内。 ● void show( ) :在屏幕上显示数组元素。 ● ~ CMatrix () :释放动态分配的空间。 2、主要函数设计 在主程序中定义数组int arr[][4]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16}作为原始数组。定义一个CMatrix类对象test,用arr初始化test,完成对该类的测试。 三、源程序清单 #include class CMatrix{ private: i nt(*a)[4]; i nt w[4][4];//变换矩阵 i nt m;//表示方阵的行和列数; public: C Matrix(int a[][4],int m) { int i,j; this->a=new int[m][4]; this->m=m; for(i=0;i<4;i++) { for(j=0;j<4;j++) { if(i==j||i+j==4-1) w[i][j]=1; else w[i][j]=0; } }