求最大值与最小值问题_第1页
求最大值与最小值问题_第2页
求最大值与最小值问题_第3页
求最大值与最小值问题_第4页
求最大值与最小值问题_第5页
已阅读5页,还剩11页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

PAGEPAGE2华北科技学院课程考查报告班级:姓名:a学号:啊课程名称:《算法设计与分析》啊课程性质:专业方向选修啊开设学期:2021-2021学年第2学期啊考核成绩:___________________________任课教师:啊2021年5月23日题目求最大值与最小值问题一、问题描述输入一列整数,求出该列整数中的最大值与最小值。二、课程设计目的通过课程设计,提高用计算机解决实际问题的能力,提高独立实践的能力,将课本上的理论知识和实际有机的结合起来,锻炼分析解决实际问题的能力。提高适应实际,实践编程的能力。在实际的编程和调试综合试题的基础上,把高级语言程序设计的思想、编程巧和解题思路进行总结与概括,通过比较系统地练习达到真正比较熟练地掌握计算机编程的基本功,为后续的学习打下基础。了解一般程序设计的基本思路与方法。三、问题分析看到这个题目我们最容易想到的算法是直接比较算法:将数组的第

1

个元素分别赋给两个临时变量:fmax:=A[1];

fmin:=A[1];

然后从数组的第

2

个元素

A[2]开始直到第

n个元素逐个与

fmax

fmin

比较,在每次比较中,如果

A[i]

>

fmax,则用

A[i]的值替换

fmax

的值;如果

A[i]

<

fmin,则用

A[i]的值替换

fmin

的值;否则保持

fmax(fmin)的值不变。这样在程序结束时的

fmax、fmin

的值就分别是数组的最大值和最小值。这个算法在最好、最坏情况下,元素的比较次数都是

2(n-1),而平均比较次数也为

2(n-1)。

如果将上面的比较过程修改为:从数组的第

2

个元素

A[2]开始直到第

n

个元素,每个

A[i]都是首先与

fmax

比较,如果

A[i]>fmax,则用

A[i]的值替换

fmax

的值;否则才将

A[i]与

fmin

比较,如果

A[i]

<

fmin,则用

A[i]的值替换

fmin

的值。这样的算法在最好、最坏情况下使用的比较次数分别是n-1和2(n-1),而平均比较次数是3(n-1)/2,因为在比较过程中,将有一半的几率出现A[i]>fmax情况。如果采用分治的思想,可以构造算法,其时间复杂度在最坏情况下和平均用时均为3n/2-2.四、主要算法(分治法)描述4.1

当我们求解某些问题时,由于这些问题要处理的数据相当多,或求解过程相当复杂,使得直接求解法在时间上相当长,或者根本无法直接求出。对于这类问题,我们往往先把它分解成几个子问题,找到求出这几个子问题的解法后,再找到合适的方法,把它们组合成求整个问题的解法。如果这些子问题还较大,难以解决,可以再把它们分成几个更小的子问题,以此类推,直至可以直接求出解为止。这就是分治策略的基本思想。

把n个元素分成两组:

A1={A[1],...,A[int(n/2)]}和A2={A[int(N/2)+1],...,A[N]}

分别求这两组的最大值和最小值,然后分别将这两组的最大值和最小值相比较,求出全部元素的最大值和最小值。如果A1和A2中的元素多于两个,则再用上述方法各分为两个子集。直至子集中元素至多两个元素为止。例如有下面一组元素:-13,13,9,-5,7,23,0,15。用分治策略比较的过程如下:图中每个方框中,左边是最小值,右边是最大值。从图中看出,用这种方法一共比较了10次,比直接比较法的14次减少4次,即约减少了1/34.2分治法在每一层递归上都有三个步骤:分解:将原问题分解为若干个规模较小,相互独立,与原问题形式相同的子问题;解决:若子问题规模较小而容易被解决则直接解,否则递归地解各个子问题;合并:将各个子问题的解合并为原问题的解。4.3在用分治法设计算法时,最好使子问题的规模大致相同。换句话说,将一个问题分成大小相等的k个子问题的处理方法是行之有效的。许多问题可以取k=2。这种使子问题规模大致相等的做法是出自一种平衡(balancing)子问题的思想,它几乎总是比子问题规模不等的做法要好。五、算法代码及运行结果5.1分治法importjava.util.Arrays;importjava.util.Scanner;publicclasslianxi{publicstaticvoidmain(String[]args){System.out.println("请输入要比较数字的总个数(数组长度):");Scannercin=newScanner(System.in);inta;a=cin.nextInt();int[]arr=newint[a];for(inti=0;i<a;i++){arr[i]=cin.nextInt();if(i==a){return;}}intresult[]=newint[2];result=minMax(arr,0,arr.length-1);System.out.println(Arrays.toString(result));}publicstaticint[]minMax(int[]arr,intl,intr){intmin=0;intmax=0;if

(l

==

r)

{

min

=

arr[l];

max

=

arr[l];

}

else

if

(l

+

1

==

r)

{

if

(arr[l]

<

arr[r])

{

min

=

arr[l];

max

=

arr[r];

}

else

{

min

=

arr[r];

max

=

arr[l];

}

}

else

{

int

mid

=

(l

+

r)

/

2;

int[]

preHalf

=

minMax(arr,

l,

mid);

int[]

postHalf

=

minMax(arr,

mid

+

1,

r);

min

=

preHalf[0]

<

postHalf[0]

?

preHalf[0]

:

postHalf[0];max=preHalf[1]>postHalf[1]?preHalf[1]:postHalf[1];}returnnewint[]{min,max};}}分治法运行结果:5.2直接法代码importjava.util.Scanner;publicclasslianxi2{publicstaticvoidmain(String[]args){System.out.println("请输入要比较数字的总个数(数组长度):");Scannercin=newScanner(System.in);inta;a=cin.nextInt();int[]list=newint[a];for(inti=0;i<a;i++){list[i]=cin.nextInt();if(i==a){return}}intmax=list[0];intmin=list[0];for(inti=0;i<a;i++){//依次比较得最大值(大值下沉)if(max<=list[i]){max=list[i];}//依次比较取最小值if(min>=list[i]){min=list[i];}}System.out.println("这些数字中最大的数字是:"+max);System.out.println("这些数字中最小的数字是:"+min);}}直接法运行结果:5.3排序法代码importjava.util.Arrays;importjava.util.Scanner;publicclasslianxi2{publicstaticvoidmain(String[]args){System.out.println("请输入要比较数字的总个数(数组长度):");Scannercin=newScanner(System.in);inta;a=cin.nextInt();int[]list=newint[a];for(inti=0;i<a;i++){list[i]=cin.nextInt();if(i==a){return;}}//先从小到大进行排序在取最大值与最小值Arrays.sort(list);System.out.println("数组按从小到大排序为:");for(inti=0;i<list.length;i++){System.out.print(list[i]+",");}System.out.println("这些数字中最大的数字是:"+list[a-1]);System.out.println("这些数字中最小的数字是:"+list[0]);}}排序法运行结果:六、各种算法比较与分析虽然所有算法运行结果相同,但是他们的运行时间却是有很大差距的,任何一种以比较为基础的搜索算法,其最坏情况下的所用时间不可能低于Θ(logn)。不可能存在其最坏情况下时间比折半搜索数量级(阶)还低的算法。事实上,折半搜索所产生的比较树的所有叶结点都在相邻的两个层次上,而且这样的二叉树使得比较树的高度最低。因此,折半搜索是解决搜索问题在最坏情况下的最优算法。七、心得体会课程设计终于做完了,虽然有些疲劳和困倦,但带给我很多的收获。算法设计与分析已经学了一个学期,有许多知识都存在似懂非懂的现象,这种现象通过实际的上机操作,实际应用,已经减少了许多。对这些知识也有了更深的理解和很好的掌握。许多困惑,有许多已经通过实际操作解决了,并能够深刻认识,但也有很多没有明白。通过课程设计,明白做一件事需要考虑到很多方面的问题的,这些都是要在实践中摸索的,这与平时做练习是不同的,但也因为平时有许多的练习基础,会使你做起程序来,更加得心应手。另外就是要把错误总结,有许多错误或者陷阱是平时自己陷进去的,因此很深刻,但也有些错误或者陷阱是自己还没有接触或者犯过的,这就应该看多些别人的总结,使自己不犯这些错误。不让自己掉进这些陷阱。这样长期总结,会对自己有很大的帮助。通过实验对各种算法有了更深一步的理解,知道了它们适合解决哪类的问题,锻炼和提高了自我的分析问题解决问题的能力,也使我对分治法的核心思想也有了更加深刻的理解和应用。参考文献:[1]《算法设计与分析》(第二版)霍红卫编著,西安电子科技大学出版社,2021

咖啡店创业计划书第一部分:背景在中国,人们越来越爱喝咖啡。随之而来的咖啡文化充满生活的每个时刻。无论在家里、还是在办公室或各种社交场合,人们都在品着咖啡。咖啡逐渐与时尚、现代生活联系在一齐。遍布各地的咖啡屋成为人们交谈、听音乐、休息的好地方,咖啡丰富着我们的生活,也缩短了你我之间的距离,咖啡逐渐发展为一种文化。随着咖啡这一有着悠久历史饮品的广为人知,咖啡正在被越来越多的中国人所理解。第二部分:项目介绍第三部分:创业优势目前大学校园的这片市场还是空白,竞争压力小。而且前期投资也不是很高,此刻国家鼓励大学生毕业后自主创业,有一系列的优惠政策以及贷款支持。再者大学生往往对未来充满期望,他们有着年轻的血液、蓬勃的朝气,以及初生牛犊不怕虎的精神,而这些都是一个创业者就应具备的素质。大学生在学校里学到了很多理论性的东西,有着较高层次的技术优势,现代大学生有创新精神,有对传统观念和传统行业挑战的信心和欲望,而这种创新精神也往往造就了大学生创业的动力源泉,成为成功创业的精神基础。大学生创业的最大好处在于能提高自己的潜力、增长经验,以及学以致用;最大的诱人之处是透过成功创业,能够实现自己的理想,证明自己的价值。第四部分:预算1、咖啡店店面费用咖啡店店面是租赁建筑物。与建筑物业主经过协商,以合同形式达成房屋租赁协议。协议资料包括房屋地址、面积、结构、使用年限、租赁费用、支付费用方法等。租赁的优点是投资少、回收期限短。预算10-15平米店面,启动费用大约在9-12万元。2、装修设计费用咖啡店的满座率、桌面的周转率以及气候、节日等因素对收益影响较大。咖啡馆的消费却相对较高,主要针对的也是学生人群,咖啡店布局、格调及采用何种材料和咖啡店效果图、平面图、施工图的设计费用,大约6000元左右3、装修、装饰费用具体费用包括以下几种。(1)外墙装饰费用。包括招牌、墙面、装饰费用。(2)店内装修费用。包括天花板、油漆、装饰费用,木工、等费用。(3)其他装修材料的费用。玻璃、地板、灯具、人工费用也应计算在内。整体预算按标准装修费用为360元/平米,装修费用共360*15=5400元。4、设备设施购买费用具体设备主要有以下种类。(1)沙发、桌、椅、货架。共计2250元(2)音响系统。共计450(3)吧台所用的烹饪设备、储存设备、洗涤设备、加工保温设备。共计600(4)产品制造使用所需的吧台、咖啡杯、冲茶器、各种小碟等。共计300净水机,采用美的品牌,这种净水器每一天能生产12l纯净水,每一天销售咖啡及其他饮料100至200杯,价格大约在人民币1200元上下。咖啡机,咖啡机选取的是电控半自动咖啡机,咖啡机的报价此刻就应在人民币350元左右,加上另外的附件也不会超过1200元。磨豆机,价格在330―480元之间。冰砂机,价格大约是400元一台,有点要说明的是,最好是买两台,不然夏天也许会不够用。制冰机,从制冰量上来说,一般是要留有富余。款制冰机每一天的制冰量是12kg。价格稍高550元,质量较好,所以能够用很多年,这么算来也是比较合算的。5、首次备货费用包括购买常用物品及低值易耗品,吧台用各种咖啡豆、奶、茶、水果、冰淇淋等的费用。大约1000元6、开业费用开业费用主要包括以下几种。(1)营业执照办理费、登记费、保险费;预计3000元(2)营销广告费用;预计450元7、周转金开业初期,咖啡店要准备必须量的流动资金,主要用于咖啡店开业初期的正常运营。预计2000元共计: 120000+6000+5400+2250+450+600+300+1200+1200+480+400+550+1000+3000+450+2000=145280元第五部分:发展计划1、营业额计划那里的营业额是指咖啡店日常营业收入的多少。在拟定营业额目标时,必须要依据目前市场的状况,再思考到咖啡店的经营方向以及当前的物价情形,予以综合衡量。按照目前流动人口以及人们对咖啡的喜好预计每一天的营业额为400-800,根据淡旺季的不同可能上下浮动2、采购计划依据拟订的商品计划,实际展开采购作业时,为使采购资金得到有效运用以及商品构成达成平衡,务必针对设定的商品资料排定采购计划。透过营业额计划、商品计划与采购计划的确立,我们不难了解,一家咖啡店为了营业目标的达成,同时有效地完成商品构成与灵活地运用采购资金,各项基本的计划是不可或缺的。当一家咖啡店设定了营业计划、商品计划及采购计划之后,即可依照设定的采购金额进行商品的采购。经过进货手续检验、标价之后,即可写在菜单上。之后务必思考的事情,就是如何有效地将这些商品销售出去。3、人员计划为了到达设定的经营目标,经营者务必对人员的任用与工作的分派有一个明确的计划。有效利用人力资源,开展人员培训,都是我们务必思考的。4、经费计划经营经费的分派是管理的重点工作。通常能够将咖啡店经营经费分为人事类费用(薪资、伙食费、奖金等)、设备类费用(修缮费、折旧、租金等)、维持类费用(水电费、消耗品费、事务费、杂费等)和营业类费用(广告宣传费、包装费、营业税等)。还能够依其性质划分成固定费用与变动费用。我们要针对过去的实际业绩设定可能增加的经费幅度。5、财务计划财务计划中的损益计划最能反映全店的经营成果。咖啡店经营者在营运资金的收支上要进行控制,以便做到经营资金合理的调派与运用。总之,以上所列的六项基本计划(营业额、商品采购、销售促进、人员、经费、财务)是咖啡店管理不可或缺的。当然,有一些咖啡店为求管理上更深入,也能够配合工作实际需要制订一些其他辅助性计划。第六部分:市场分析2019-2021年中国咖啡市场经历了高速增长的阶段,在此期间咖啡市场总体销售的复合增长率到达了17%;高速增长的市场为咖啡生产企业带给了广阔的市场空间,国外咖啡生产企业如雀巢、卡夫、ucc等企业纷纷加大了在中国的投资力度,为争取未来中国咖啡市场的领先地位打下了良好的基础。咖啡饮料主要是指速溶咖啡和灌装即饮咖啡两大类咖啡饮品;在速溶咖啡方面,2018-2021年间中国速溶咖啡市场规模年均增长率到达16%,显示出还处于成长阶段的中国速溶咖啡市场的高增长性和投资空间;在灌装即饮咖啡方面,2008-2010年间中国灌装即饮咖啡市场年均增长率也同样到达15%;未来几年,中国咖啡饮料的前景仍将被看好。现今咖啡店主要是以连锁式经营,市场主要被几个集团垄断。但由于几个集团的咖啡店并没有个性主题,很难配合讲求特式的年青人。我们亦有思考到其他饮品店的市场竞争状况,但发现这些类似行业多不是以自助形式经营,亦很难配合讲求效率的年青人。故我

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论