数据结构上机作业(三)

一.上机内容

1、实现串的模式匹配算法。
2、实现稀疏矩阵的三元组表压缩存储方法
3 *、三元组表压缩存储方法基础上实现稀疏矩阵的转置,主要涉及矩阵中每一行非零元素的个数的求解方法和转置矩阵的每一行中的第一个元素在其三元组表中的存储位置的计算。

二.代码实现

1、实现串的模式匹配算法。
1.Brute-Force模式匹配算法
/**
     * 返回模式串t在主串从start开始的第一次匹配位置,匹配失败返回-1
     * @param t
     * @param start
     * @return
     */
    public int indexof_BF(IString t,int start){
   
        // 当主串比模式串长的时候才开始比较
        if (this!=null && t!= null && t.length() > 0 && this.length > t.length()) {
   
            // i表示主串中某个子串的序号
            int slen, tlen, i = start, j = 0;
            // 主串的长度
            slen = this.length();
            // 匹配串的长度
            tlen = t.length();
            // i和j都在比较范围内
            while ((i < slen) && (j < tlen)) {
   
                // j为模式串当前字符的下标
                if (this.charAt(i) == t.charAt(j)) {
   
                    i++;
                    j++;
                } else {
   
                    // 继续比较主串中的下一个子串
                    // i-j+1就是在本次比较前,往后走一个字符
                    i = i - j + 1;
                    // 模式串下标退回0
                    j = 0;
                }
            }
            // 如果匹配成功,返回子串序号
            // 运行到这里,不一定是j超出了范围,还有可能是i超出了范围,i超出范围但是j没有,说明匹配失败
            if (j >= t.length()) {
   
                return i - tlen;
            } else {
   
                return -1;
            }
        }
        return -1;
    }
2.KMP模式匹配算法
/**
     * next[j]函数
     * @param T
     * @return      返回模式串的next[j]数组
     */
    public int[] getNext(IString T){
   
        // next[]数组
        int[] next = new int[T.length()];
        //主串指针
        int j = 1;
        // 模式串指针
        int k = 
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实验1: 1)熟悉Vc 6.0环境 2)用两种算法实现1-1/x+1/x*x-1/x*x*x+1/x*x*x*x…., 注(algo1-1,algo1-2) 实验2:线性 1) 顺序的合并:实现P26算法2.7,La=1 2 3 4 5, Lb=2 4 6 8 10。要求得到合并后的Lc=1 2 3 4 5 6 8 10 注(algo2-4 ) 2) 一元多项式加法:Pa=Pa+Pb,并销毁一元多项式Pb 3) 一元多项式乘法:Pa=Pa*Pb,并销毁一元多项式Pb 实验3:栈和队列 1) 利用栈求解迷宫问题;行列各为10(包括外墙),迷宫内墙单元数为18。 2) 利用栈和递归求解Hanoi塔问题,圆盘数3。 3) 利用非循环顺序队列采用广度搜索法求解迷宫问题(一条路径);行列各为5(包括外墙),迷宫内墙单元数为2。 实验4:串 1) 模式匹配改进算法:KMP算法实现4.6,4.7,4.8算法。 实验5: 数组和广义 1) 求稀疏矩阵的加,乘和转置矩阵。 2) 求广义的深度。 实验6:树和二叉树 1) 求赫夫曼编码。(w存放n个字符的权值(均>0),构造赫夫曼树HT,并求出n个字符的赫夫曼编码HC) 实验7:图 1)实现教科书图7.33的程序,并能求出任意两点的最短路径。 实验8:动态存储管理 1) 边界标识法,程序实现教科书算法8.1 2) 伙伴系统,程序实现教科书算法8.2 实验9:查找 1) 哈希的查找及其分析:以书图9-25为例。 实验10:内部排序 1) 以书10-4的数据,程序实现直接插入排序,折半排序和2路插入排序。 2) 以书图10.6的数据,程序实现快速排序。 3) 以书图10.9的数据,程序实现树形选择排序。 4) 以书图10.13的数据,程序实现归并排序。 5) 以书图10.14的数据,程序实现链式基数排序。 实验11: 外部排序 1) 以书图11.4的数据,程序实现多路平衡归并排序。 2)以书图11.5的数据,程序实现置换-选择排序。 实验12:文件 1)以书图12.4的数据,程序实现顺序文件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值