用C++编写一个使用类模板对数组进行排序、查找和求元素和的程序

用C++编写一个使用类模板对数组进行排序、查找和求元素和的程序

#include<iostream>
using namespace std;

//类模板
template<class T>
class vector
{
public:
void sort(T a[],int n);
T sum(T a[],int n);
int search(T e, T a[], int n);
};

//排序
template<class T>
void vector<T>::sort(T a[],int n)
{
T temp;
bool exchange;
for(int i = 1; i < n; i++)
{
exchange = false;
for(int j = n-1; j >= i; j--)
if(a[j] < a[j-1])
{
temp = a[j]; a[j] = a[j-1]; a[j-1] = temp;
exchange = true;
}
if(!exchange)
return;
}
}

//求和
template<class T>
T vector<T>::sum(T a[],int n)
{
T sum = a[0];
for(int i = 1; i < n; i++)
sum += a[i];
return sum;
}

//查找
template<class T>
int vector<T>::search(T e, T a[], int n)
{
for(int i = 0; i < n; i++)
if(a[i] == e)
return i;
return -1;
}

void main()
{
int data[5] = {5,4,3,2,1};
vector<int> obj;

cout<<"数组和为:"<<obj.sum(data,5)<<endl;
cout<<"数字4在数组中的位置是:"<<obj.search(4,data,5)<<endl;

cout<<"排序前数组各元素为:"<<endl;
for(int i = 0; i < 5; i++)
cout<<data[i]<<" ";
cout<<endl;

cout<<"排序后数组各元素为:"<<endl;
for(i = 0; i < 5; i++)
cout<<data[i]<<" ";
cout<<endl;
}
温馨提示:内容为网友见解,仅供参考
第1个回答  2010-04-21
#include <iostream>
#include <cstring>
#include <vector>

using namespace std;

template<typename T> class handle_array {
private:
T *arr;
int length;
public:
explicit handle_array()
{
}
handle_array(int n)
{
length = n;
arr = new T[n];
memset(arr, 0, sizeof(T)*n);
}
handle_array(T *p, int n)
{
length = n;
arr = new T[n];
for (int i=0; i<n; i++)
arr[i] = p[i];
}
void sort();
int locate(T x);
T sum();
void print();
virtual ~handle_array()
{
delete []arr;
}
};
template<typename T>
void handle_array<T>::sort()
{
T temp;
for (int i=0; i<length; i++)
for (int j=i+1; j<length; j++)
if (arr[i] > arr[j]) {
temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
template<typename T>
int handle_array<T>::locate(T x)
{
int index = -1;
for (int i=0; i<length; i++)
if (arr[i] == x) {
index = i;
break;
}
return index;
}
template<typename T>
T handle_array<T>::sum()
{
T sum=0;
for (int i=0; i<length; i++)
sum += arr[i];
}
template<typename T>
void handle_array<T>::print()
{
for (int i=0; i<length; i++)
cout << arr[i] << ' ';
cout << endl;
}

int main()
{
int a[] = {1991, 8, 5};
double b[] = {1990, 8, 25};
handle_array<int> int_array(a, sizeof(a)/sizeof(a[0]));
int_array.sort();
int_array.print();
handle_array<double> double_array(b, sizeof(b)/sizeof(b[0]));

return 0;
}

用C++编写一个使用类模板对数组进行排序、查找和求元素和的程序
cout<<"数组和为:"<<obj.sum(data,5)<<endl;cout<<"数字4在数组中的位置是:"<<obj.search(4,data,5)<<endl;cout<<"排序前数组各元素为:"<<endl;for(int i = 0; i < 5; i++)cout<<data[i]<<" ";cout<<endl;cout<<"排序后数组各元素为:"<<endl;for(i = 0; i < ...

C ++编写一个使用类模板对数组进行排序、查找和求元素和的程序。
~Array(){} void sort(); \/\/ 排序 int seek(T key); \/\/ 查找指定的元素 T sum(); \/\/ 求和 void disp(); \/\/ 显示所有的元素 };template<class T> void Array<T>::sort(){ int i,j;T temp;for(i=1;i<n;i++)for(j=n-1;j>=i;j--)if(set[j-1]>set[j]){ temp=s...

\/\/用c++将N个数从小到大排列输出,数据类型可以是整型,单精度型,双精度...
system("pause");} 其实最简单的解决方法是用sort函数,只需#include<algorithm>就可以了,默认升序排序。sort(数组首地址即数组名,首地址+数组长度,排序方式)如果不写最后的参数则默认升序排列,以上面的程序为例,可以这样写:sort(a,a+n); \/\/前面不要忘记头文件 这个方法很简单的 ...

VC++怎么降序排列?
首先看sort函数见下表:函数名 功能描述 sort 对给定区间所有元素进行排序 stable_sort 对给定区间所有元素进行稳定排序 partial_sort 对给定区间所有元素部分排 partial_sort_copy 对给定区间复制并排序 nth_element 找出给定区间的某个位置对应的元素 is_sorted 判断一个区间是否已经排好序 partition 使得...

is_partitioned函数应用举例
本示例程序使用C++编写,旨在展示`is_partitioned`函数的应用。程序首先导入必要的库,包括用于输入输出的,用于排序的,用于创建向量的,以及用于创建函数对象的。程序还导入了和库以生成随机数。这里的`is_partitioned`函数用于检测向量是否可以按照某种条件进行分区。具体来说,它检查向量中是否满足以下条件...

Modern C++ 学习笔记(21)——模板元编程
模板元编程在C++中的应用旨在于在编译期而非运行期进行计算,从而提高程序性能和灵活性。下面将介绍模板元编程的几个关键应用实例,包括编译期阶乘计算、循环展开、打印元组、类型trait等。首先,让我们通过一个简单的示例了解编译期阶乘计算。通过使用模板递归,我们可以设计一个模板函数,用于在编译期计算一...

【C++】模仿tcmalloc从零实现一个高并发内存池(一)
我们首先写出定长内存池类ObjMemoryPool的大致框架,同时使用可变模板参数class T表示定长内存池存储的对象的类型和long long Nums来表示每次内存池预先申请多少个T大小的空间。同时我们后面会通过一个_freelist来实现对回收对象的管理,_remainder则表示内存池剩余的字节数,同时我们会留出接口New(),Delete(),来调用以...

c++模板学习:一个例子搞懂SFINAE
通过上述的步骤,我们不仅成功地构建了一个灵活的加法接口,还深入理解了SFINAE机制在模板编程中的应用。虽然SFINAE机制带来的代码可能不够直观,但它为模板编程提供了一种强大的工具,允许我们在编译时进行类型检查和控制。此外,通过结合C++模板和SFINAE,我们能够构建出类型安全、高效且功能强大的程序。

C++程序设计 模板与STL
我写个吧 template<typename T> T Small(T t1,T t2){ return t1<t2?t1:t2;} \/\/话说不用模板 const char *Small(const char *pa,const char *pb){ return strcmp(pa,pb)<0?pa:pb;} const int SIZE = 100;template<typename T>class Stack { public:Stack();~Stack();void Push(T...

C++ vector和list的区别
C++编程语言中,vector与list是两种常用的数据结构。它们在实现上和使用场景上有明显的区别,理解这些差异将有助于你更高效地运用C++进行程序开发。首先,vector和list都是模板类,支持动态数组功能,但它们在内存管理和操作效率上有显著差异。vector是连续存储元素,提供快速随机访问,适用于频繁读取元素的场景...

相似回答