CareerCup 14.6

Implement Circular Array


/*
 * Career Cup 14.6
 * 
 */

package CareerCup;

import java.util.Iterator;

public class CircularArray<T> implements Iterable<T> {
	private T items[];
	private int head;

	public CircularArray(int size) {
		items = (T[]) new Object[size];
		head = 0;
	}
	
	public int Size() {
		return items.length;
	}

	public void rotate(int rightShift) {
		if (rightShift < 0) {
			rightShift += items.length;
		}
		head = (head + rightShift) % items.length;
	}

	public int convert(int index) {
		int i = (index + head) % items.length;

		return i;
	}

	public T get(int index) {
		if (index < 0 || index >= items.length) {
			throw new java.lang.IndexOutOfBoundsException();
		}

		int i = convert(index);
		return items[i];
	}

	public void set(int index, T item) {
		int i = convert(index);
		items[i] = item;
	}

	@Override
	public Iterator<T> iterator() {
		return new CircularArrayIterator<T>(this);
	}

	private class CircularArrayIterator<TI> implements Iterator<TI> {
		private int current = -1; //current reflects the offset from the rotated head
		private TI[] refItems;
		
		public CircularArrayIterator(CircularArray<TI> c) {
			refItems = c.items;
		}
		
		@Override
		public boolean hasNext() {
			return current < refItems.length - 1;
		}

		@Override
		public TI next() {
			current++;
			int i = convert(current);
			return refItems[i];
		}

		@Override
		public void remove() {
			throw new UnsupportedOperationException();
		}

	}
	
	/**
	 * @param args
	 */
	public static void main(String[] args) {
		CircularArray<Integer> arr;
		arr = new CircularArray<Integer>(5);
		for(int i = 0; i < arr.Size(); i++) {
			Integer in = new Integer(i + 10);
			arr.set(i, in);
		}
		
		System.out.println("Before rotate...");
		for(Integer i : arr) {
			System.out.println(i);
		}
		System.out.println("After rotated...");
		arr.rotate(2);
		for(Integer i : arr) {
			System.out.println(i);
		}
		
		
	}
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值