《数据结构》实验一: VC编程工具的灵活使用(实验报告)

本文详细介绍了利用C++模板和多文件工程设计完成特定任务的实验过程,包括单文件结构程序设计、函数模板实现及类模板应用,同时涵盖了程序调试技巧和输出结果的实例。

一..实验目的

     复习巩固VC编程环境的使用,以及C++模板设计。

1.回顾并掌握VC单文件结构程序设计过程。

2.回顾并掌握VC多文件工程设计过程

3.掌握VC程序调试过程。

4.回顾C++模板和模板的程序设计。


二.实验内容

1. 设计一个单文件结构程序完成从键盘输入两个数,输出二者的“和”和“积”的结果。要求如下:

1)设计函数来计算“和”和“积”,在主函数中调用,并能考虑重载函数,使整数和小数均能计算。

2)分别使用单步调试和断点调试来调试程序。并多次运行力求熟练调试方法。

2.使用函数的模板来实现上述功能。

3.使用一个类来实现上述功能。要求:

  1)使用类模板

  2)使用多文件:类的声明有头文件中;类的函数定义一个源文件中,在主程序文件中设计主函数程序,在实例化输出结果。


三.源代码

(1)

#include<iostream>
using namespace std;


int sum(int a,int b)
{
int c;
c=a+b;
return c;
}//实现整数下a和b相加的函数


int sum(int i1,int m,int n)
{
int o;
o=m*n;
return o;
}//实现整数下m与n相乘的函数


float sum(int j,int l,float a1,float b1)
{
float c;
c=a1+b1;
return c;
}//实现小数下a和b相加的函数


float sum(int k,int k1,int l1,float m1,float n1)
{
float o;
o=m1*n1;
return o;
}//实现小数下m与n相乘的函数


void main()
{
char sel;
cout<<"尊敬的用户:"<<endl;
cout<<"          您即将进行求两个数字的“和”与“积”的操作,请问输入的数字中是否包括小数?(Y/N):";
cin>>sel;
if(sel=='Y' || sel=='y' ) 
{
float x,y,h,h1;
   cout<<"请输入两个数字:";
   cin>>x>>y;
sum(0,0,x,y);
h=sum(0,0,x,y);
cout<<"这两个数的和是:"<<h<<endl;
        sum(0,0,0,x,y);
h1=sum(0,0,0,x,y);
cout<<"这两个数的积是:"<<h1<<endl;
}
else
{
int x,y,h,h1;
   cout<<"请输入两个数字:";
   cin>>x>>y;
    sum(x,y);
h=sum(x,y);
cout<<"这两个数的和是:"<<h<<endl;
sum(0,x,y);
h1=sum(0,x,y);
cout<<"这两个数的积是:"<<h1<<endl;
}
}


(2)

#include<iostream>
using namespace std;
template<class A>
void sum(A a,A b,A m,A n)
{
cout<<"请输入两个数字:";
cin>>a>>b;
m=a+b;
cout<<"这两个数的和是:"<<m<<endl;
n=a*b;
    cout<<"这两个数的积是:"<<n<<endl;
}
void main()
{
    int a1,b1,m1,n1;
double a2,b2,m2,n2;
char sel;
cout<<"尊敬的用户:"<<endl;
cout<<"          您即将进行求两个数字的“和”与“积”的操作,请问输入的数字中是否包括小数?(Y/N):";
cin>>sel;
if(sel=='Y' || sel=='y' ) 
sum(a2,b2,m2,n2);
else
sum(a1,b1,m1,n1);
}




(3)

#include<iostream>
using namespace std;
class sum
{
int a,b;
float c,d;
public:
 void zhengshu(int i);
      void xiaoshu();
};
void sum::zhengshu(int i)
{
cout<<"请输入两个数字:";
cin>>a>>b;
cout<<"这两个数的和是:"<<a+b<<endl;
    cout<<"这两个数的积是:"<<a*b<<endl;
}
void sum::xiaoshu()
{
cout<<"请输入两个数字:";
cin>>c>>d;
cout<<"这两个数的和是:"<<c+d<<endl;
    cout<<"这两个数的积是:"<<c*d<<endl;
}
void main()
{
sum q,w;
char sel;
cout<<"尊敬的用户:"<<endl;
cout<<"          您即将进行求两个数字的“和”与“积”的操作,请问输入的数字中是否包括小数?(Y/N):";
cin>>sel;
if(sel=='Y' || sel=='y' ) 
w.xiaoshu();
else
q.zhengshu(0);
}




 

四.实验心得

       通过这次实验,我了解到还有很多东西不够熟练,必须好好学习,天天向上。













内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值