#include<iostream> using namespace std; #define list_size 10000 #define listincreament 10000 typedef int element; typedef int Status; typedef struct { element *elem; int listsize; //顺序表长度 int length; //分配内存空间 } Sqlist; Status initializer_list(Sqlist &L) //初始化 { L.elem = new int[list_size]; if(!L.elem) return -1; //分配内存失败 L.length=0; L.listsize = list_size; return 0; } Status creatnewlist(Sqlist &L,int n) //创建顺序表 { int i,j; L.elem = new int [list_size]; if(!L.elem) return -1; else { L.length = n; //设置顺序表初始长度为n for(i=0;i<L.length;i++) //输入n个数 { cin>>L.elem[i]; for(j=0;j<i;j++) //遍历 前i-1个元素是否与新元素相同 { if(L.elem[i]==L.elem[j]) //如果相同 { L.length--; //新顺序表长度-1 i--;//后一个,从新表依次开始存放元素 } } } } return 0; }
void display(Sqlist &L) //输出顺序表中的所有元素 { int i; for(i=0;i<L.length-1;i++) { cout<<L.elem[i]<<" "; } cout<<L.elem[i]<<endl; } int main() { Sqlist L; int n,m,i,T; cin>>n; while(n--) { cin>>m; initializer_list(L); creatnewlist(L,m); //Remove(L); display(L); } return 0; }
转载于:https://www.cnblogs.com/CCCrunner/p/6444618.html
相关资源:JAVA上百实例源码以及开源项目