QQ登录

只需一步,快速开始

登录 | 立即注册 | 找回密码

主题

帖子

荣誉

VIP至尊会员

Rank: 15Rank: 15Rank: 15

积分
6
查看: 58|回复: 2

编译又又又又不过了向大佬递我

[复制链接]
最佳答案
0 
累计签到:5 天
连续签到:1 天
歆煜 发表于 4 天前 582 | 显示全部楼层 |阅读模式

马上注册加入鱼C,享用更多服务吧^_^

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
#include <iostream>
using namespace std;

template<typename T,int size>class SeqList{
        T slist[size];
        int maxsize;
        int last;
public:
        SeqList(){last=-1;maxsize=size;}
        void insert(T a);
        void insertOrder(T a);
        void show();
        int searchOrder(T key);
        bool delete1(int k);
        void delete2();

};

template<typename T,int size>void SeqList<T,size>::insert(T a){
        last++;
        slist[last]=a;
}
template<typename T,int size>void SeqList<T,size>:: insertOrder(T a){
        last++;
        slist[last]=a;
        int j=last;
        while(j>0 && a<slist[j-1]){
                        slist[j]=slist[j-1];
                        j--;}
                slist[j]=a;
       
}

template<typename T,int size>void SeqList<T,size>::show(){
        int i=0;
        for(i=0;i<=last;i++){
                cout<<slist[i]<<'\t';
        }
}
template<typename T,int size>int SeqList<T,size>::searchOrder(T key){
        int i=0;
        while(i<=last && slist[i]!=key)i++;
        if(i>last) return -1;
        else return i;
}
template<typename T,int size>bool SeqList<T,size>::delete1(int k){
        if(k>=0){
                last--;
                for(int j=k;j<=last;j++)slist[j]=slist[j+1];
                return true;
        }
        return false;
}
template<typename T,int size>void SeqList<T,size>:: delete2(){
        for(int i=0;i<last;i++){
                if(slist[i]==slist[i+1]){
                        last--;
                        for(int j=k;j<=last;j++)slist[j]=slist[j+1];
                }
        }
}


class Element{
        int key;
public:
        bool operator < (Element ele){return key<ele.key;}
        bool operator == (Element ele){return key==ele.key;}
       
};

int main(){   
    SeqList<int,20> l1;      
    int a;
        cout<<"输入数组1:";

    for(int i=0;i<10;i++){      
                cin>>a;
                l1.insertOrder(a);         
}
   cout<<"输入数组2:";
    for(i=0;i<10;i++){      
                cin>>a;
                l1.insertOrder(a);         
}
        l1.delete2();
        l1.show();  cout<<endl;
        return 0;
}
楼层
跳转到指定楼层
最佳答案
0 
累计签到:5 天
连续签到:1 天
歆煜  楼主| 发表于 4 天前 | 显示全部楼层
j=k改为j=i
最佳答案
756 
累计签到:311 天
连续签到:51 天
ba21 发表于 4 天前 | 显示全部楼层

回帖奖励 +20

#include <iostream>
using namespace std;

template<typename T,int size>class SeqList{
        T slist[size];
        int maxsize;
        int last;
public:
        SeqList(){last=-1;maxsize=size;}
        void insert(T a);
        void insertOrder(T a);
        void show();
        int searchOrder(T key);
        bool delete1(int k);
        void delete2();

};

template<typename T,int size>void SeqList<T,size>::insert(T a){
        last++;
        slist[last]=a;
}
template<typename T,int size>void SeqList<T,size>:: insertOrder(T a){
        last++;
        slist[last]=a;
        int j=last;
        while(j>0 && a<slist[j-1]){
                        slist[j]=slist[j-1];
                        j--;}
                slist[j]=a;
        
}

template<typename T,int size>void SeqList<T,size>::show(){
        int i=0;
        for(i=0;i<=last;i++){
                cout<<slist<<'\t';
        }
}
template<typename T,int size>int SeqList<T,size>::searchOrder(T key){
        int i=0;
        while(i<=last && slist!=key)i++;
        if(i>last) return -1;
        else return i;
}
template<typename T,int size>bool SeqList<T,size>::delete1(int k){
        if(k>=0){
                last--;
                for(int j=k;j<=last;j++)slist[j]=slist[j+1];
                return true;
        }
        return false;
}
template<typename T,int size>void SeqList<T,size>:: delete2(){
        for(int i=0;i<last;i++){
                if(slist==slist[i+1]){
                        last--;
                        for(int j=i;j<=last;j++)slist[j]=slist[j+1];
                }
        }
}


class Element{
        int key;
public:
        bool operator < (Element ele){return key<ele.key;}
        bool operator == (Element ele){return key==ele.key;}
        
};

int main(){   
    SeqList<int,20> l1;      
    int a;
        cout<<"输入数组1:";

    for(int i=0;i<10;i++){      
                cin>>a;
                l1.insertOrder(a);         
}
   cout<<"输入数组2:";
    for(i=0;i<10;i++){      
                cin>>a;
                l1.insertOrder(a);         
}
        l1.delete2();
        l1.show();  cout<<endl;
        return 0;
}

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

小甲鱼强烈推荐 上一条 /1 下一条

    移动客户端下载(未启用)
    微信公众号

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备11014136号

Copyright 2018 鱼C论坛 版权所有 All Rights Reserved.

Powered by Discuz! X3.1 Copyright
© 2001-2018 Comsenz Inc.    All Rights Reserved.

小黑屋|手机版|Archiver|鱼C工作室 ( 粤公网安备 44051102000370号 | 粤ICP备11014136号

GMT+8, 2018-4-20 05:29

快速回复 返回顶部 返回列表