51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1780|回复: 0
打印 上一主题 下一主题

cstrlist1.h

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2009-12-14 17:55:03 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
//字符串链表类
#ifndef CStrList_H
#define CStrList_H
#include "base.h"
//#include "intlist.h"
//#include "cstring.h"
class CStrList
{
protected:
CStrList *head;
CStrList *tail;
CStrList *next;
CStrList *freepoint; //游标指针
CString m_num; //成员的值
int m_count;//成员数量
public:
CStrList operator +(CStrList &_obj);
void operator =(CStrList &_obj);
void operator =(CString &_str);
CStrList operator +(char *_value);
bool operator ==(CStrList &_obj);
CStrList ()
{
  head = tail = next = freepoint = NULL;
  //m_num = NULL;
  m_count = 0;
}
CStrList (CString &_str)
{
  head = tail = next = freepoint = NULL;
  m_count = 0;
  Append (_str);
}
CStrList (char* _value)
{
  head = tail = next = freepoint = NULL;
  m_count = 0;
  Append (_value);
}

~CStrList ()
{
  Close();
}
/*
CStrList (CStrList& _CStrList)
{
  head = tail = next = freepoint = NULL;
  m_count = 0;
  for (int i = 1;i <= _CStrList.Count();i++)
  {
   Append(_CStrList.Get(i));
  }
}
*/
/*########################*/
//void CStrList:: Insert (CString &_obj,int _pos)
//插入链表中的指定位置
/*########################*/
void CStrList:: Insert (CString &_obj,int _pos)
{
  if (_pos < 1)
  {
   PRINT("Insert--parameter pos error!")
   return;
  }
  //插入的位置大于现有成员数量
  if (_pos > Count())
  {
   Append(_obj);
   return;
  }
  //插入到第1个位置
  else if (_pos == 1)
  {
   CStrList *item;
   NEW(item,CStrList);
   //item->m_num = new(char);
   item->m_num = _obj;
   item->next = head;
   head = item;
   m_count++;//成员数加1
   return;
  }
  //插入到中间位置
  else
  {
   CStrList *tmp;
   tmp = head;
   int t_pos = 1;
   while (tmp != NULL)
   {
    if ((t_pos + 1) == _pos)
    {
     CStrList *item;
     NEW(item,CStrList);
   
     item->m_num = _obj;
     
     CStrList  &front = *tmp;//指向要插入位置的前一个成员   
     tmp = tmp->next;//指向要插入的位置;
     front.next = item;
     item->next = tmp;
     m_count++;//成员数加1
     return;
    }
    tmp=tmp->next;
    t_pos++;
   }
  }   
}
/*########################*/
//void CStrList:: Insert (CStrList &_obj,int _pos)
//插入链表中的指定位置
/*########################*/
void CStrList:: Insert (CStrList &_obj,int _pos)
{
  if (_pos < 1)
  {
   PRINT("Insert---parameter pos error!")
   return;
  }
  CStrList* tmp;
  tmp = _obj.head;
  int i = 0;
  while (tmp != NULL)
  {
   Insert(_obj.Get(i+1),_pos + i);
   i++;
   tmp = tmp->next;
  }
  return;
}
/*########################*/
//void CStrList:: Insert (char *_value,int _pos)
//插入链表中的指定位置
/*########################*/
void CStrList:: Insert (char *_value,int _pos)
{
  CString obj;
  obj = _value;
  Insert(obj,_pos);
  return;
}
/*########################*/
//void Close ()
//修改成员的值
/*########################*/
void Close ()
{
  //CStrList* tmp;
  for (int i = 1;i <= m_count;i++)
  {
   //tmp = head;
   //head = head->next;
   //DELETE(tmp);   
   Retrieve();
  }
  head = tail = next = freepoint = NULL;
  m_count = 0;
  return;
}

[ 本帖最后由 wwtsanmao 于 2009-12-18 17:03 编辑 ]
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-11-24 03:33 , Processed in 0.063697 second(s), 26 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

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