鱼C论坛

 找回密码
 立即注册
查看: 4176|回复: 8

[已解决]c++ 链表旋转

[复制链接]
发表于 2021-9-27 18:00:14 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

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

x
请问这题目啥意思
循环链表吗还是双向循环之类的
最佳答案
2021-9-27 21:03:07
万千只cnm 发表于 2021-9-27 20:29
他 不是说p往前指向第一个节点吗

是从当前位置一直向前(向头结点)
这个 theChain 是一个双向链表,可以从某一个节点,向前和向后两个方向遍历元素
1.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-9-27 18:04:54 | 显示全部楼层
23 题是什么?
是不是和这个 24 题有关系?
这确实给的内容太少了,很多东西都得猜
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-9-27 18:05:56 | 显示全部楼层
没有 theChain 这个变量的类型?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-9-27 18:55:24 | 显示全部楼层
23题是这个
2.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-9-27 18:56:36 | 显示全部楼层
人造人 发表于 2021-9-27 18:05
没有 theChain 这个变量的类型?

chain是个自定义的类
template<class T>
struct chainNode{//结构体也能构造 成员,函数
     T element;
     chainNode<T> *next;

     chainNode(){}
      chainNode(const T& element){ this->element= element;}
      chainNode(const T& element,chainNode<T> * next){
           this->element= element;
           this->next=next;
      }
};
template<class T>
class chain : public linearList<T>{//抽象类的派生类
    public:
      chain(int init =10);
      chain(const chain<T>&);
      ~chain();

       bool empty() const {return listSize == 0;}//1
        int size() const {return listSize ;} //1
         T& get(int theIndex) const;//返回索引的元素 
         int indexOF(const T& theElment) const;//第一次出现的索引
         void erase(int theIndex);
        void insert(int theIndex,const T& theElement);
        void output(ostream & out) const;
        void swap(chain<T>& theChain);//交换两个链表
 //      /////习题 
        void setSize(int theSize);//若多于 则删除  1
        void set(int theIndex,T theElement);//置换索引元素
        int lastIndexOf(T theElement);//元素最后出现索引
        void removeRange(int fromIndex,int toIndex);//删除索引范围内的所有节点

        T& operator[](int index);
        bool operator==(chain<T> & x);
        bool operator!=(chain<T>& x);
        bool operator<(chain<T>& x);
        void leftShift(int i);//左移动元素 (删除—)
        void reverse();//颠倒元素顺序 
        void meld(chain<T>& a,chain<T>& b);//交替合并
        void clean();//清空
        void merge(chain<T>& a,chain<T>& b);//有序合并 
        void split(chain<T>& a,chain<T>& b);//分奇偶索引
        void circularShift(int i);//向左循环索引
        void insertSort();//链表排序

///////////////
      friend ostream& operator<<(ostream& out,const chain<T>& x){ x.output(out); return out;}
        protected:
          void checkIndex(int theIndex) const;
          chainNode<T>* firstNode;
          int listSize;
};
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-9-27 19:47:00 | 显示全部楼层
对于这个题目,双向链表就可以了
不需要双向循环链表
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-9-27 19:49:01 | 显示全部楼层
到最后一个节点的时候
l 指向最后一个节点
p = NULL
就可以了
不需要循环
题目也没要求循环
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-9-27 20:29:38 | 显示全部楼层
人造人 发表于 2021-9-27 19:49
到最后一个节点的时候
l 指向最后一个节点
p = NULL

他 不是说p往前指向第一个节点吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-9-27 21:03:07 | 显示全部楼层    本楼为最佳答案   
万千只cnm 发表于 2021-9-27 20:29
他 不是说p往前指向第一个节点吗

是从当前位置一直向前(向头结点)
这个 theChain 是一个双向链表,可以从某一个节点,向前和向后两个方向遍历元素
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-23 03:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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