就是顺序表的增删改查,挺有意思的
1 public class SequentialList { 2 3 /** 4 * The maximal length of the list. It is a constant. 5 */ 6 public static final int MAX_LENGTH = 10; 7 8 /** 9 * The actual length not exceeding MAX_LENGTH. 10 */ 11 int length; 12 13 /** 14 * The data stored in an array. 15 */ 16 int[] data; 17 18 /** 19 * Construct an empty sequential list. 20 */ 21 public SequentialList() { 22 length = 0; 23 data = new int[MAX_LENGTH]; 24 } 25 26 /** 27 * Construct a sequential list using an array. 28 * 29 * @param paraArray 30 */ 31 public SequentialList(int[] paraArray) { 32 data = new int[MAX_LENGTH]; 33 length = paraArray.length; 34 35 // Copy data. 36 for (int i = 0; i < paraArray.length; i++) { 37 data[i] = paraArray[i]; 38 } // Of for i 39 }// Of for the second constructor 40 41 /** 42 * Overrides the method claimed in Object, the superclas of any class. 43 */ 44 public String toString() { 45 String resultString = ""; 46 47 if (length == 0) { 48 return "empty"; 49 } 50 51 for (int i = 0; i < length - 1; i++) { 52 resultString += data[i] + ", "; 53 } // Of for i 54 55 // the last member of resultString 56 resultString += data[length - 1]; 57 58 return resultString; 59 }// Of for toString 60 61 public void reset() { 62 length = 0; 63 }// Of reset 64 65 /** 66 * The entrance of the program. 67 * 68 * @param args 69 */ 70 public static void main(String args[]) { 71 int[] tempArray = { 1, 4, 6, 9 }; 72 SequentialList tempFirstList = new SequentialList(tempArray); 73 System.out.println("After initialized, the list is: " + tempFirstList.toString()); 74 System.out.println("Again, the list is: " + tempFirstList); 75 76 int tempValue = 4; 77 int tempPosition = tempFirstList.indexOf(tempValue); 78 System.out.println("The position of " + tempValue + " is " + tempPosition); 79 80 tempValue = 5; 81 tempPosition = tempFirstList.indexOf(tempValue); 82 System.out.println("The position of " + tempValue + " is " + tempPosition); 83 84 tempValue = 5; 85 tempPosition = 2; 86 tempFirstList.insert(tempPosition, tempValue); 87 System.out.println("After inserting " + tempValue + " to position " + tempPosition + ", the list is: " + tempFirstList); 88 89 tempValue = 10; 90 tempPosition = 8; 91 tempFirstList.insert(tempPosition, tempValue); 92 System.out.println("After inserting " + tempValue + " to position " + tempPosition + ", the list is: " + tempFirstList); 93 94 tempPosition = 3; 95 tempFirstList.delete(tempPosition); 96 System.out.println("After deleting data at position " + tempPosition + ", the list is: " + tempFirstList); 97 98 for (int i = 0; i < 8; i++) { 99 tempFirstList.insert(i, i); 100 System.out.println("After inserting " + i + " to position " + i + ", the list is: " + tempFirstList); 101 }// Of for i 102 103 tempFirstList.reset(); 104 System.out.println("After reset, the list is: " + tempFirstList); 105 }// Of main 106 107 /** 108 * Find the index of the given value. 109 * If it appears in multiple positions,simply return the first one. 110 * 111 * @param paraValue 112 * @return 113 */ 114 public int indexOf(int paraValue) { 115 int tempPosition = -1; 116 for (int i = 0; i < length; i++) { 117 if (data[i] == paraValue) { 118 tempPosition = i; 119 break; 120 } // Of if 121 } // Of for i 122 123 return tempPosition; 124 }// Of indexOf 125 126 /** 127 * Insert a value to a position. 128 * If the list is already full, do nothing. 129 * 130 * @param paraPosition 131 * @param paraValue 132 * @return 133 */ 134 public boolean insert(int paraPosition, int paraValue) { 135 if (length == MAX_LENGTH) { 136 System.out.println("List full."); 137 return false; 138 } // Of if 139 140 if ((paraPosition < 0) || (paraPosition > length)) { 141 System.out.println("The position " + paraPosition + " is out of bounds."); 142 return false; 143 } // Of if 144 145 // From tail to head, the last one is moved to a new position. 146 // Because length < MAX_LENGTH, no exceeding occurs. 147 for (int i = length; i > paraPosition; i--) { 148 data[i] = data[i - 1]; 149 } // Of for i 150 151 data[paraPosition] = paraValue; 152 length++; 153 154 return true; 155 }// Of insert 156 157 /** 158 * Delete a value at a position. 159 * 160 * @param paraPosition 161 * @return 162 */ 163 public boolean delete(int paraPosition) { 164 if ((paraPosition < 0) || (paraPosition > length)) { 165 System.out.println(); 166 return false; 167 } // Of if 168 169 // From head to tail. 170 for (int i = paraPosition; i < length - 1; i++) { 171 data[i] = data[i + 1]; 172 }// Of for i 173 174 length--; 175 176 return true; 177 }// Of delete 178 179 }// Of class SequentialList