[]运算符重载——已解决

要求: 在对数组元素下标引用时进行检查, 并在下标越界时终止程序。

实现:对数组进行排序,并实现元素查找

#include <iostream>
#include <stdlib.h>
using namespace std;
 
template <class T>
class BoundArray
{
    int n;
    T *data;
public:
    BoundArray(int n_val, T *p)
    {
        int i;
        n = n_val;
        data = new T [n];
        for(i = 0; i < n; i++)
            data[i] = p[i];
    }
    
	BoundArray &operator[](const int &r)      // 最好是 const ,并且必须要引用
	{
		if(r < 0 || r >= n)
			exit(1);
		else return *this;
	}
	
    void sort()
    {
        int i, j;
        T temp;
        for(i = 0; i < n-1; i++)
        {
            for(j = 0; j < n-1; j++)
            {
                if(data[j] > data[j+1])
                {
                    temp = data[j];
                    data[j] = data[j+1];
                    data[j+1] = temp;
                }
            }
        }
    }
    int search(T target)
    {
        int low = 0; 
        int high = n-1;
        int mid = (low+high)/2;
 
        while(low <= high)/
        {
            mid = (low+high)/2;
            if(data[mid] == target)
                return mid;
            else if(data[mid] < target)
                low = mid+1;
            else high = mid-1;
        }
        return -1;
    }
    void display()
    {
        int i;
        for(i = 0; i < n; i++)
            cout << data[i] << " ";
        cout << endl;
    }
    ~BoundArray()
    {
        delete []data;
    }
};
 
int main()
{
    int T, n, i;
    char ch;
 
    cin >> T;
    while(T--)
    {
        cin >> ch;
        if(ch == 'I')
        {
            cin >> n;
            int *data = new int [n];
            for(i = 0; i < n; i++)
                cin >> data[i];
            int target;
            cin >> target;
            BoundArray<int> a(n, data);
            a.sort();
            a.display();
            cout << a.search(target) << endl;
            delete []data;
        }
        else if(ch == 'D')
        {
            cin >> n;
            double *data = new double [n];
            for(i = 0; i < n; i++)
                cin >> data[i];
            double target;
            cin >> target;
            BoundArray<double> a(n, data);
            a.sort();
            a.display();
            cout << a.search(target) << endl;
            delete []data;
        }
        else
        {
            cin >> n;
            char *data = new char [n];
            for(i = 0; i < n; i++)
                cin >> data[i];
            char target;
            cin >> target;
            BoundArray<char> a(n, data);
            a.sort();
            a.display();
            cout << a.search(target) << endl;
            delete []data;
        }
    }
    return 0;
}

样例输入

2
I 2
1 2
2
D 33.5 6.2 2.9
2.1

样例输出

1 2
1
2.9 3.5 6.2
-1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值