| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 614 人关注过本帖
标题:求完善,在vc++上运行可以倒序输出一个字符串
只看楼主 加入收藏
hy247767221
Rank: 2
来 自:襄樊
等 级:论坛游民
帖 子:41
专家分:22
注 册:2011-7-27
结帖率:87.5%
收藏
已结贴  问题点数:5 回复次数:4 
求完善,在vc++上运行可以倒序输出一个字符串
#include<stdio.h>
#include<stdlib.h>

typedef struct NODE
{
    char data;
    struct NODE *next;
}NODE;

NODE *push_stack(NODE *head);
void free_space(NODE *p);


int main()
{
    NODE *head = NULL,*p = NULL;//链表都要有头结点 和头指针

    p = push_stack(head);

    while(p)
    {
        putchar(p->data);
        p = p->next;
    }

    putchar(10);

    free_space(p);

    return 0;
}

NODE *push_stack(NODE *head)
{
    char string;
    NODE *stack = NULL;

    while(1)
    {
        string = getchar();
        if(string == '\0')
            break;
        stack = (NODE *)malloc(sizeof(struct NODE));//倒叙插入法  栈特性
        stack->data = string;
        stack->next = head;
        head = stack;
    }
    return head;
}

void free_space(NODE *p)//直接递归释放就可以了
{
    if(p->next)
        free_space(p->next);
    free(p);
}
搜索更多相关主题的帖子: 字符串 
2011-07-27 22:01
lz1091914999
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:四川
等 级:贵宾
威 望:37
帖 子:2011
专家分:5959
注 册:2010-11-1
收藏
得分:3 
程序代码:
#include <stdio.h>
#include <stdlib.h>

typedef struct node NODE, * PNODE;

struct node {
    char  value;
    PNODE pNext;
};


PNODE  init_stack(void);                // 初始化Stack,成功初始化反回栈顶指针,否则返回NULL
void   destroy_stack(PNODE pHead);      // 销毁Stack,需要提供一个栈顶指针。
int    push(PNODE pHead, char value);   // 压栈函数,需要提供一个栈顶指针、一个值,成功压栈返回1,否则返回0
char * pop(PNODE pHead, char * pValue); // 出栈函数,需要提供一个栈顶指针、一个存放值变量的地址,成功出栈返回pValue,否则返回NULL

int main(void) {
    PNODE  pHead = init_stack();
    char * str = "abcdefghijklmnopqrstuvwxyz";
    char * pStr = str;
    char   value;

    while(*pStr)
        push(pHead, *pStr++);

    while(pop(pHead, &value) != NULL)
        printf("%c", value);

    printf("\n");
    destroy_stack(pHead);
    return 0;
}

PNODE init_stack(void) {
    PNODE pHead = (PNODE)malloc(sizeof(NODE));

    pHead->pNext = NULL;

    return pHead;
}

void destroy_stack(PNODE pHead) {
    PNODE temp;  /*
    char  value; */

    while(pHead->pNext != NULL) {
        temp = pHead->pNext->pNext;
        free(pHead->pNext);
        pHead->pNext = temp;
    }

/*
    while(pop(pHead, &value) != NULL)
        ;
*/
    free(pHead);
}

int push(PNODE pHead, char value) {
    PNODE newNode = (PNODE)malloc(sizeof(NODE));

    if(newNode == NULL)
        return 0;

    newNode->value = value;
    newNode->pNext = pHead->pNext;
    pHead->pNext = newNode;

    return 1;
}

char * pop(PNODE pHead, char * pValue) {
    PNODE temp;

    if(pHead->pNext == NULL)
        return NULL;

    *pValue = pHead->pNext->value;
    temp = pHead->pNext->pNext;
    free(pHead->pNext);
    pHead->pNext = temp;

    return pValue;
}

图片附件: 游客没有浏览图片的权限,请 登录注册



[ 本帖最后由 lz1091914999 于 2011-7-28 00:39 编辑 ]

My life is brilliant
2011-07-28 00:38
lz1091914999
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:四川
等 级:贵宾
威 望:37
帖 子:2011
专家分:5959
注 册:2010-11-1
收藏
得分:1 
程序代码:
#include <stdio.h>

void reverse_output(char * pStr) {
    if(*pStr) {
        reverse_output(pStr + 1);
        printf("%c", *pStr);
    }
}

int main(void) {
    char * str = "abcdefghijklmnopqrstuvwxyz";
    reverse_output(str);
    return 0;
}

My life is brilliant
2011-07-28 12:00
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:1 
sacnf("%s",str);
printf("%s",strrev(str));

欢迎来到我的博客:http://blog..cn/noisunyuhong
2011-07-28 12:53
落叶深蓝色
Rank: 8Rank: 8
来 自:山东
等 级:蝙蝠侠
帖 子:319
专家分:807
注 册:2010-12-8
收藏
得分:0 
程序代码:
        char s[100];
    int i;
    scanf("%s",s);
    for(i=strlen(s)-1;i>=0;i--)
        printf("%c\n",s[i]);
2011-07-28 17:34
快速回复:求完善,在vc++上运行可以倒序输出一个字符串
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.023878 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved