java数据结构链表,堆栈,队列,串相关专题分析与扯谈-串结构

该篇是该系列的最后一篇文章,讲的是串结构,下面我给出串结构相关的设计code

功能接口设计思路
(1)取字符charAt(index) :取index下标的字符返回。
(2)求长度length():返回串的长度。
(3)比较compareTo(anotherString):比较当前对象串和串anotherString的Unicode码值的大小。
(4)取子串substring(beginIndex, endIndex):取当前对象串中从beginIndex下标开始、至endIndex下标的前一下标止的子串。
(5)连接concat(str):把串str连接到当前对象串的末尾。
(6)插入子串insert(str, pos):在当前对象串的第pos个字符前插入子串str。
(7)删除子串delete(beginIndex, endIndex):删除当前对象串中从beginIndex下标开始、至endIndex下标的前一下标止的子串 。
(8)输出串值myPrint():输出当前对象的串值。
//建议重写Object类的toString()方法。使用toString()代替
(9)查找子串index(subStr, start):在当前对象串的start下标开始,查找是否存在子串subStr。

直接上code~~

public class MyString {

    private char[] value; //字符数组
    private int count; //字符串的长度

    //从源串指定下标开始拷贝指定长度的字符串到目标串指定为下标开始
    //char[] src:源串
    //int srcPos:源串的开始下标
    //char[] dst:目标串
    //int dstPos:目标串开始下标
    //int length:拷贝长度
    public static void arrayCopy(char[] src,int srcPos,char[] dst,int dstPos,int length)
    {   
        //如果源串起始下标+拷贝长度>源串长度或者目标串起始下标+拷贝长度>目标串长度
        if(srcPos+length>src.length||dstPos+length>dst.length)
        {
            throw new StringIndexOutOfBoundsException(length);
        }
        for(int i=0;i<length;i++)
        {
            dst[dstPos++]=src[srcPos++];
        }
    }

    //构造方法1,构造一个空字符串
    public MyString()
    {
        value=new char[0];
        count=0;
    }
    //构造方法2,实现从一个字符中提取出新的字符串。
    //char[] value:已有的字符数组。
    //int offset:起始下标
    //int count:拷贝的个数
    public MyString(char[] value,int offset,int count)
    {
        //判断起始位置是否<0
        if(offset<0)
        {
           throw new StringIndexOutOfBoundsException(offset);   
        }
        //判断count是否<0
        if(count<0)
        {
           throw new StringIndexOutOfBoundsException(count);
        }
        //判断起始位置+count是否大于value字符串的长度

        if(offset+count>value.length)
        {
           throw new StringIndexOutOfBoundsException(offset+count);
        }
        this.value = new char[count];
        this.count = count;
        arrayCopy(value,offset,this.value,0,count);

    }

    //构造方法3,根据已有的字符数组,构造新的字符串
    public MyString(char[] value)
    {
        this.count = value.length;
        this.value = new char[count];
        arrayCopy(value,0,this.value,0,count);
    }

    //构造方法4,使用JDK本身的String类,构造新的字符串
    public MyString(String str)
    {
      char[] chararray = str.toCharArray();
      value = chararray;
      count = chararray.length;
    }

    @Override
    public String toString() {
        // TODO Auto-generated method stub
        String str="";
        for(int i=0;i<count;i++)
        {
            str+=value[i];
        }
        return str;
    }

    public int length()
    {
        return count;
    }


    public char charAt(int index)
    {
       if(index<0||index>=count)
       {
           throw new StringIndexOutOfBoundsException(index); 
       }
       return value[index];
    }

    //比较两个字符串的大小
    //如果当前字符串大于比较字符串,返回一个正整数
    //如果当前字符串等于比较字符串,返回0
    //如果当前字符串小于比较字符串,返回负整数

    public int compareTo(MyString anotherStr)
    {
        int len1= this.count;
        int len2 = anotherStr.length();
        int n = Math.min(len1, len2);
        char[] v1 = value;
        char[] v2 = anotherStr.value;
        int i=0;
        while(i<n)
        {
          char c1 =v1[i];
          char c2 =v2[i];
          if(c1!=c2)
          {
              return c1-c2;
          }
          i++;
        }

        return len1-len2;
    }

}

测试Test

public class Test {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
      char[] c1={'c','h','i','n','a'};
      char[] c2={'I','l','o','v','e',' ','c','h','i','n','a'};
      //构造方法1
      MyString str1= new MyString();

      //构造方法3
      MyString str2 = new MyString(c1);

      //构造方法2
      MyString str3 = new MyString(c2,1,5);

      //构造方法4
      MyString str4 = new MyString("Hello");

      MyString str5 = new MyString("China");

      System.out.println(str1);
      System.out.println(str2);
      System.out.println(str3);
      System.out.println(str4);

      System.out.println(str4.length());
      System.out.println(str3.charAt(2));

      System.out.println(str2.compareTo(str5));

    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值