鱼C论坛

 找回密码
 立即注册
查看: 4294|回复: 7

[争议讨论] 第22讲 线性表17 程序是错的!!!

[复制链接]
发表于 2013-5-17 15:46:16 | 显示全部楼层 |阅读模式

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

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

x
那道凯撒加密题。老师上课的程序在输入负数值时会出错!

现在贴上正确代码:
#include <stdio.h>
#include <stdlib.h>

#define OK 1
#define ERROR 0

typedef char ElemType;
typedef int Status;


typedef struct DualNode
{
        ElemType data;
        struct DualNode* prior;
        struct DualNode* next;
}DualNode;


Status initList(DualNode** L){

        DualNode* p, *q;
        int i;

        *L = (DualNode*)malloc(sizeof(DualNode));
        if(!(*L)){
                return ERROR;
        }

        (*L)->next = (*L)->prior = NULL;
        p = *L;

        for(i=0; i<26; i++){

                // q指向新建立的节点
                q = (DualNode*)malloc(sizeof(DualNode));
                if( !q ){
                        return ERROR;
                }

                q->data = 'A' + i;
                q->prior = p;
                q->next = p->next;
                p->next = q;

                // p指向q前一个节点
                p = q;
        }

        p->next = (*L)->next;
        (*L)->next->prior = p;
        return OK;
}

void casar(DualNode** L, int i){

        if(i > 0){
                do{
                        (*L) = (*L)->next;
                }while(--i);
        }

        if(i < 0){
                DualNode* p = (*L)->next;
                for(i; i<0; i++){
                        //printf("p is %c\n", p->data);
                        (p) = (p)->prior;
                }
                (*L) = p->prior;
        }
}


int main(){

        DualNode* L;
        int i, n;

        initList(&L);
        printf("Input an integer:\n");
        scanf("%d", &n);
        casar(&L, n);

        if(L == NULL){
                printf("L is NULL\n");
        }
        else{
                //printf("%c\n", L->data);
        }


        for(i=0; i<26; i++){
                L = L->next;
                printf("%c", L->data);
        }
        printf("\n");
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2013-5-20 14:20:38 | 显示全部楼层
牛人。。。激动人心,无法言表!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-5-21 03:25:50 | 显示全部楼层
学习了 好东西
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-5-21 12:27:26 | 显示全部楼层
真是难得给力的帖子啊。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-12-8 10:57:39 | 显示全部楼层
正在学习,看看
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-12-8 11:50:24 | 显示全部楼层
难免会有错误
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-12-18 20:58:56 | 显示全部楼层
谢谢楼主分享
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2013-12-18 21:10:29 | 显示全部楼层
牛人啊~~~真的很给力啊
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 04:55

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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