欢迎来到沃文网! | 帮助中心 分享知识,传播智慧!
沃文网
全部分类
  • 教学课件>
  • 医学资料>
  • 技术资料>
  • 学术论文>
  • 资格考试>
  • 建筑施工>
  • 实用文档>
  • 其他资料>
  • ImageVerifierCode 换一换
    首页 沃文网 > 资源分类 > DOC文档下载
    分享到微信 分享到微博 分享到QQ空间

    java关于单纯形法的课程设计.doc

    • 资源ID:854784       资源大小:206.82KB        全文页数:20页
    • 资源格式: DOC        下载积分:20积分
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: QQ登录 微博登录
    二维码
    微信扫一扫登录
    下载资源需要20积分
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,下载更划算!
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    java关于单纯形法的课程设计.doc

    1、目录第1章 引言21.1 设计任务21.2 设计目的21.3 设计要求2第2章 主体设计部分32.1 头文件32.1.1 头文件代码32.1.2 截图42.2 选择命令操作42.2.1 控制代码42.2.2 截图42.3 执行命令操作52.3.1 操作代码52.3.2 截图102.4 换入换出变量的计算102.4.1 操作代码102.4.2 截图112.5 执行计算结果11第3章 设计总结11第4章 参考文献12第5章 附录12第1章 引言1.1 设计任务 利用所学过的Java知识,结合课程设计实例,编写管理运筹学中的线性规划问题中的单纯形法,让我们更进一步的了解和学习Java知识,对管理运筹

    2、学有更深一层次的认识.用Java编程实现单纯形法的基本算法,该算法能够实现指定的线性问题.1.2 设计目的通过此次课程设计,让我们发现此门课程学习中的不足和存在的薄弱环节,予以补充和加强.综合运用在课程学习过程中所学的知识,同时为了实现课程设计的规定成果进行更深入的理论学习和实践拓展.培养独立思考和解决问题的能力,探索和创新的能力.为进一步的学习和深入研究打下基础,培养起做项目的兴趣.1)实现运筹学中线性规划中的单纯形法的基本算法;2)综合应用Java语言,结合数学方法与思路更进一步认识和掌握Java编程语言的风格及应用;3)通过此次设计,希望我们能够在日后的学习和工作中能够更多的使用该门语言

    3、,将该门语言作为一门有效地工具运用在实际生活问题中.1.3 设计要求通过简单的Java程序实现单纯形法的最基本解及最优解的求解,过程中实现变量的输入、输出的转化变换,简单明了的代码行间里透露出单纯形法的基本求解步骤,完成最基础的一般性的最小、最大值的求解.1)执行程序后出现个人的基本信息以及即将执行的步骤;2)利用键盘输入的方法实现输入步骤;3)输入之后将即将要解决的单纯性问题在屏幕上显示出来;4)然后根据提示要求进行一步一步的输入操作;5)最后输出计算结果完成操作.第2章 主体设计部分2.1 头文件2.1.1 头文件代码 执行该程序时出现在屏幕上的界面,其下为该界面的设计代码:package

    4、 单纯形法;import java.util.Scanner;public class test SuppressWarnings( null )public static void main(String args) /用Java语言来编一个单纯形法编程算法 /(1)输入和显示数学模型 /(2)进行标准型变换并输出 /(3)单纯形法算法,进行换基迭代,求出基础解(可行解、最优解) /(4)输出解 System.out.println(*交通运输学院 java课程设计*); System.out.println(*专 业 信管1001班*); System.out.println(* 李 凯

    5、201000829 *); System.out.println(* 单纯形法 线行规划问题 *);2.1.2 截图图12.2 选择命令操作2.2.1 控制代码在即将进入操作命令之前的界面:System.out.println(输入数学模型); Scanner s = new Scanner(System.in); System.out.print(目标函数求最大值或最小值(1 or 0):); int m=s.nextInt();2.2.2 截图 图22.3 执行命令操作2.3.1 操作代码利用键盘输入执行指定的线性规划问题:例如 max z = 6+4x2;2x1 + x2 =10;x1

    6、+ x2 =8; x2 =7; 满足System.out.print(有几个决策变量:); int n=s.nextInt(); System.out.print(约束条件中含=号的条件有几个?:); int m2=s.nextInt(); System.out.print(约束条件中含=号的条件有几个? ); int m3=s.nextInt(); /System.out.println(n); int B=new intm1n; int C=new intm2n; int D=new intm3n; int BUM=new intm11; int CUM=new intm21; int D

    7、UM=new intm31;/输入目标函数 System.out.println(输入目标函数:); int A=new intn; String SS=new Stringn; Scanner sm = new Scanner(System.in); / for(int i=1;i=0) SSi-1=Ai-1+X+i+; else if(Ai-10) SSi-1=Ai-1+X+i+-; Scanner smm = new Scanner(System.in); System.out.print(X+n+的系数是:); An-1=smm.nextInt(); SSn-1=An-1+X+n; /

    8、输出目标函数 for(int i=0;iSS.length;i+) System.out.print(SSi); /输入约束条件中含=号的条件 for(int i=1;i=m1;i+) System.out.println( ); /int B=new intm1n; String MMM=new Stringn; System.out.println(输入第+i+个约束条件中含=号的); for(int j=1;jn;j+) Scanner sN = new Scanner(System.in); System.out.print(X+j+的系数是:); Bi-1j-1=sN.nextInt

    9、(); MMMj-1=Bi-1j-1+X+j+; Scanner smmm = new Scanner(System.in); System.out.print(X+n+的系数是:); Bi-1n-1=smmm.nextInt(); /MMMn-1=Nn-1+X+n+=+; /输入常数项 System.out.println(输入常数项:); /int BUM=new intm11; Scanner sNN= new Scanner(System.in); BUMi-10=sNN.nextInt(); MMMn-1=Bi-1n-1+X+n+=+BUMi-10;/输出约束条件中含=号的条件 fo

    10、r(int K=0;K=的条件 for(int i=1;i=号的); for(int j=1;j=+CUMi-10;/输出约束条件中含=号的条件 for(int K=0;KAAA.length;K+) System.out.print(AAAK); /输入约束条件中含=的条件 for(int i=1;i=m3;i+) System.out.println(); /int D=new intm3n; String BBB=new Stringn; System.out.println(输入第+i+个约束条件中含=的); for(int j=1;jn;j+) Scanner BN = new Sc

    11、anner(System.in); System.out.print(X+j+的系数是:); Di-1j-1=BN.nextInt(); BBBj-1=Di-1j-1+X+j+; Scanner BNN = new Scanner(System.in); System.out.print(X+n+的系数是:); Di-1n-1=BNN.nextInt();/ 输入常数项 System.out.println(输入常数项:); /int DUM=new intm31; Scanner sBBB= new Scanner(System.in); DUMi-10=sBBB.nextInt(); BB

    12、Bn-1=Di-1n-1+X+n+=+DUMi-10;/输出约束条件中含=号的条件 for(int K=0;KBBB.length;K+) System.out.print(BBBK); /参数输入完成! System.out.println(); System.out.println(参数输入完成!); /输出数学模型 System.out.println(); System.out.println(输出数学模型); if ( m!=1) System.out.print(目标函数: MIN z=); else System.out.print(目标函数: MAX z=); for(int

    13、i=1;in;i+) System.out.print(Ai-1+X+i+); System.out.print(An-1+X+n); System.out.println();2.3.2 截图图32.4 换入换出变量的计算2.4.1 操作代码计算得出换入、换出变量,计算换入换出变量,源代码如下:2.4.2 截图 图4 图52.5 执行计算结果 图6 第3章 设计总结 在这为期短暂的一周的课程设计时间里,真是让我匪夷所思,让我真正的体会到了什么才是java程序实践设计的应用.只有通过我们从现实生活中抽取题材,再根据自己所学的程序设计方面的只是加以应用才能使我们见识理论与实践结合的妙效.这次自己

    14、所选的题目是单纯形算法的实现,自己觉得在设计过程中学习了很多,补漏了很多,做完之后还是觉得自己设计的不够理想,我坚信在往后的学习道路上我还会有很多的机会去做这方面的设计. 感谢老师为我们设计了本次课程设计,给我们充分学习和查阅网络、图书馆资源的时间,让我们认识到了学习的充分必要性.在以后的学习生活中再接再厉努力做好每一个点滴.第4章 参考文献Java程序设计经典教程 电子工业出版社Java课程设计(第二版) 清华大学出版社Java面对对象程序设计 清华大学出版社第5章 附录20package 单纯形法;import java.util.Scanner;public class test Sup

    15、pressWarnings( null )public static void main(String args) /用Java语言来编一个单纯形法编程算法 /(1)输入和显示数学模型 /(2)进行标准型变换并输出 /(3)单纯形法算法,进行换基迭代,求出基础解(可行解、最优解) /(4)输出解 System.out.println(*交通运输学院 java课程设计*); System.out.println(*专 业 信管1001班*); System.out.println(* 李 凯 201000829 *); System.out.println(* 单纯形法 线行规划问题 *); S

    16、ystem.out.println(输入数学模型); Scanner s = new Scanner(System.in); System.out.print(目标函数求最大值或最小值(1 or 0):); int m=s.nextInt(); System.out.print(有几个决策变量:); int n=s.nextInt(); System.out.print(约束条件中含=号的条件有几个?:); int m2=s.nextInt(); System.out.print(约束条件中含=号的条件有几个? ); int m3=s.nextInt(); /System.out.printl

    17、n(n); int B=new intm1n; int C=new intm2n; int D=new intm3n; int BUM=new intm11; int CUM=new intm21; int DUM=new intm31;/输入目标函数 System.out.println(输入目标函数:); int A=new intn; String SS=new Stringn; Scanner sm = new Scanner(System.in); / for(int i=1;i=0) SSi-1=Ai-1+X+i+; else if(Ai-10) SSi-1=Ai-1+X+i+-;

    18、 Scanner smm = new Scanner(System.in); System.out.print(X+n+的系数是:); An-1=smm.nextInt(); SSn-1=An-1+X+n;/输出目标函数 for(int i=0;iSS.length;i+) System.out.print(SSi); /输入约束条件中含=号的条件 for(int i=1;i=m1;i+) System.out.println( ); /int B=new intm1n; String MMM=new Stringn; System.out.println(输入第+i+个约束条件中含=号的);

    19、 for(int j=1;jn;j+) Scanner sN = new Scanner(System.in); System.out.print(X+j+的系数是:); Bi-1j-1=sN.nextInt(); MMMj-1=Bi-1j-1+X+j+; Scanner smmm = new Scanner(System.in); System.out.print(X+n+的系数是:); Bi-1n-1=smmm.nextInt(); /MMMn-1=Nn-1+X+n+=+; /输入常数项 System.out.println(输入常数项:); /int BUM=new intm11; Sc

    20、anner sNN= new Scanner(System.in); BUMi-10=sNN.nextInt(); MMMn-1=Bi-1n-1+X+n+=+BUMi-10;/输出约束条件中含=号的条件 for(int K=0;K=的条件 for(int i=1;i=号的); for(int j=1;j=+CUMi-10;/输出约束条件中含=号的条件 for(int K=0;KAAA.length;K+) System.out.print(AAAK); /输入约束条件中含=的条件 for(int i=1;i=m3;i+) System.out.println(); /int D=new int

    21、m3n; String BBB=new Stringn; System.out.println(输入第+i+个约束条件中含=的); for(int j=1;jn;j+) Scanner BN = new Scanner(System.in); System.out.print(X+j+的系数是:); Di-1j-1=BN.nextInt( BBBj-1=Di-1j-1+X+j+; Scanner BNN = new Scanner(System.in); System.out.print(X+n+的系数是:); Di-1n-1=BNN.nextInt();/ 输入常数项 System.out.

    22、println(输入常数项:); /int DUM=new intm31; Scanner sBBB= new Scanner(System.in); DUMi-10=sBBB.nextInt(); BBBn-1=Di-1n-1+X+n+=+DUMi-10;/输出约束条件中含=号的条件 for(int K=0;KBBB.length;K+) System.out.print(BBBK); /参数输入完成! System.out.println(); System.out.println(参数输入完成!);/输出数学模型 System.out.println(); System.out.prin

    23、tln(输出数学模型); if ( m!=1) System.out.print(目标函数: MIN z=); else System.out.print(目标函数: MAX z=); for(int i=1;in;i+) System.out.print(Ai-1+X+i+); System.out.print(An-1+X+n); System.out.println();/转换成标准形式 System.out.println(转换成标准形式:); int N=n+m1; System.out.println(转换后的决策变量的个数为:+N+个);/转换含=的约束条件 int AA=new

    24、 intm1N+1; for(int i=0;im1;i+) for(int j=0;jn;j+) AAij=Bij; for(int j=n;jn+m1;j+) AAij=0; AAiN=BUMi0; for(int i=0;im1;i+) AAii+2+=1; / for(int i=0;im1;i+) / /for(int j=0;j+iN+1;j+) / /AAij+i+=1; / / System.out.println(标准形式为:); for(int i=0;im1;i+) for(int j=0;j=n+m1;j+) System.out.print(AAij+ ); Syst

    25、em.out.println(); /求基础基 System.out.println(求基础基:); for(int i=0;in;i+) System.out.println(X+(i+1)+=0); for(int i=n+1;i=n+m1;i+) System.out.println(X+i+=+BUMi-n-10); /以Xm作为基变量 System.out.println(以基变量作为转换:); for(int i=1;i=m1;i+) System.out.print(X+(n+i)+=+BUMi-10); for(int j=1;j=n;j+) /System.out.print

    26、ln(X+(n+i)+=); if(Bi-1j-1!=0) System.out.print(-+Bi-1j-1+X+j); System.out.println(); /确定换出变量 System.out.print(确定换入变量:);/一般选择在目标函数中正系数最大的变量作为换出的变量 int temp; int i=0; temp=i; for(i=0;iA0) temp=i; System.out.println(X+(temp+1); /选择换出变量 System.out.println(选择换出变量:); /得到满足约束条件的一个可行解(保证其余分量为非负) /Ai是换出变量 fo

    27、r(int j=0;jn;j+) float M1=null; float M2=null; if(M1.length!=M2.length) throw new ArithmeticException(); else double max=M10/M20; for(int P=0;P0) max=M1P/M2P; break; for(int Q=0;Q=M1Q/M2Q)&(M2Q0) max=M1Q/M2Q; / 将XQ作为换出变量 /输出最优解 double max=0; for(int r=0;rB.length;r+) for(int j=0;j0) if(maxtmp) max=tmp; if(Bjr0) if(maxtmp) max=tmp; System.out.println(max=+max);.忽略此处.


    注意事项

    本文(java关于单纯形法的课程设计.doc)为本站会员(精***)主动上传,沃文网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知沃文网(点击联系客服),我们立即给予删除!




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服点击这里,给沃文网发消息,QQ:2622162128 - 联系我们

    版权声明:以上文章中所选用的图片及文字来源于网络以及用户投稿,由于未联系到知识产权人或未发现有关知识产权的登记,如有知识产权人并不愿意我们使用,如有侵权请立即联系:2622162128@qq.com ,我们立即下架或删除。

    Copyright© 2022-2024 www.wodocx.com ,All Rights Reserved |陕ICP备19002583号-1

    陕公网安备 61072602000132号     违法和不良信息举报:0916-4228922