看流星社区

 找回密码
 注册账号
查看: 2168|回复: 0

C++ 双链表实现字符串的存储与逆序输出

[复制链接]

该用户从未签到

发表于 2016-9-11 19:44:03 | 显示全部楼层 |阅读模式
#include "stdafx.h"
#include <iostream>
#include<stdio.h>
#include <malloc.h>
#include <stdlib.h>
#include <string>
#include <conio.h>
using namespace std;

#define  N 20;
typedef char DataType; //定义节点数据域类型
typedef struct node  //节点类型定义
{
DataType data[20];
struct node *next;  //节点的指针域指向下一个节点
struct node *pre;
}ListNode;

typedef ListNode *LinkList;
ListNode *p;          //定义节点指针
LinkList head;        //定义链表头指针

ListNode * CreateList()  //创建链表
{
char ch[20];
LinkList head = (LinkList) malloc (sizeof(ListNode)); //生成头结点
ListNode *s,*r;
r = head;
head->pre=NULL;
head ->data[0] ='*';  //随意写的
s =(LinkList)malloc(sizeof(ListNode));
    gets(s->data);
while (s->data[0] != 'Q' && s->data[0] !='q')  //按Q q退出
  {
r->next = s;
s->pre = r;
r = s;
s =(LinkList)malloc(sizeof(ListNode));
gets(s->data);
  }
r->next = NULL;
free(s);
return head;
}   

void printList(LinkList head) //输出链表
{
ListNode *p;
int i = 0;
if (head != NULL)
{
p =head;
while (p->next != NULL)
{
p = p->next;
}
        
while (p->pre != NULL)
{
cout <<p->data<<endl;
p = p->pre;
}
}
}


int main(int argc,char* argv[])
{
LinkList list;
list = CreateList();
printList(list);
}
点击按钮快速添加回复内容: 支持 高兴 激动 给力 加油 苦寻 生气 回帖 路过 感恩
您需要登录后才可以回帖 登录 | 注册账号

本版积分规则

小黑屋|手机版|Archiver|看流星社区 |网站地图

GMT+8, 2024-3-19 10:55

Powered by Kanliuxing X3.4

© 2010-2019 kanliuxing.com

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