ImageVerifierCode 换一换
格式:DOC , 页数:20 ,大小:220.37KB ,
资源ID:1596421      下载积分:20 文钱
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,省得不是一点点
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wenke99.com/d-1596421.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(算法设计与分析.doc)为本站会员(创****公)主动上传,文客久久仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知文客久久(发送邮件至hr@wenke99.com或直接QQ联系客服),我们立即给予删除!

算法设计与分析.doc

1、0算法设计与分析实验报告班级:软件 82 班学号:08161032姓名:郑雅楠提交日期:2011-01-101实 验 一 矩 阵 相 称 问 题一、 问题描述编写程序,实现两个 2k2k 矩阵相乘的 Strassen 算法。二、 问题分析将 n 阶矩阵分块为 m*m 的矩阵。用传统方法求两个 m 阶矩阵的乘积需要计算 O(m3)次 2 个 2k*2k 矩阵的乘积。用 Strassem 矩阵乘法计算 2 个 2k*2k 矩阵的乘积需要的计算时间为 O(7k),因此算法的计算时间为 O(7k*m3)。三、 算法设计按下列步骤可以完成 strassen 矩阵相乘算法(1) 请求用户输入矩阵的阶并构造

2、对象,用随机产生的办法构造矩阵 A 和矩阵 B。(2) 判断是否超过 2 阶矩阵,如果超过,则用分治法进行分割,然后进行 22 的矩阵的计算。(3) 参考书上的算法,并计算出 M1 到 M7 的值,然后再计算出C11,C12,C21, 和 C22具体代码参见算法实现部分。四、 算法实现实现代码:import java.util.*;/* Strassen类 */class CStrassenint n,tn; /tn为实际人数,n为比tn大的最小 2次幂int A;int B;int C; /C为结果/* 构造函数 */CStrassen(int num)tn = n = num;Random

3、 rand = new Random(47);/种随机种,47是magic numberif( (numwhile (num != 0)num = num 1;i+;num = 1;n = num 0, 0, 0, ,要求找iwiv1in出 n 元 0/1 向量 ,使得 ,而且12(,.),0,1nixxn1ixc达到最大。因此 0/1 背包问题是一个特殊的整数规划问题。1ivx0nkw1maxivn1ic0,ixi三、 算法设计令 0/1 背包问题的最优值为 m(i,j),即背包容量是 j,可选择物品为i,i+1,n 时 0/1 背包问题的最优值。由 0/1 背包问题的最优子结构性质,可以建

4、立计算 m(i,j)的递归式如下:maxm(i+1,j),m(i+1,j- )+ iwivijm(i,j)=m(i+1,j)nvnjwm(n,j)=0 nk四、 算法实现实现代码:import java.util.Arrays;import java.util.Random;9public class Bag public static double knapsack(double w, double v, double c,double p, int head) int n = v.length - 1;headn + 1 = 0;p00 = 0;p01 = 0;int left = 0, right = 0, next = 1;headn = 1;for (int i = n; i = 1; i-) int k = left;for (int j = left; j c)break;double y = pj0 + wi, m = pj1 + vi;while (k pnext - 11) pnext0 = y;

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。