鱼C论坛

 找回密码
 立即注册
12
返回列表 发新帖
楼主: 小甲鱼

第二十讲 线性表15(视频+课件+源代码)

[复制链接]
发表于 2015-11-7 13:14:22 | 显示全部楼层
1136736388 发表于 2015-5-21 21:10
拉丁方阵  没有源代码。。。。。楼主加油,鱼C加油!我们都看好你哦!

我有 自己写的
/************************************************************************/
/* 2015年11月7日11:53:57
功能:实现拉丁方阵
目的:由于是自己写的,那么就是练习一下自己的循环链表的操作与创建.*/
/************************************************************************/
# include<stdio.h>
# include<stdlib.h>
# include<stdbool.h>


typedef struct node
{
        int data;
        struct node * pNext;
}Node,*pNode;

pNode create_loop_list(int n);
void traverse_loop_list(pNode);

int main(void)
{
        //pNode pHead;
        int i = 0; 
        int n = 0;
        //int *a = 0;
        printf("请输入拉丁方阵的边数:n = ");
        scanf("%d", &n);
        printf("\n");
        pNode pRear = create_loop_list(n);
        //traverse_loop_list(pRear);
        printf("拉丁方阵如下:\n");
        for (i = 0; i < n ; ++i)
        {
                pRear = pRear->pNext;
                traverse_loop_list(pRear);

        }
        return 0;
}
 
pNode create_loop_list(int n)
{
        //int n = 0;
        int i = 0;
        int cunt = 0;
        pNode pHead = (pNode)malloc(sizeof(Node));
        if (NULL == pHead)
        {
                printf("\a内存分配失败!!");
                exit(-1);
        }
        pNode pTail = pHead;
        pTail->pNext = NULL;


         //a = &n;

        for (i = 0; i < n; ++i)
        {
                pNode pNew = (pNode)malloc(sizeof(Node));
                if (NULL == pNew)
                {
                        printf("\a内存分配失败!!");
                        exit(-1);
                }
                pNew->data = i+1 ;
                pTail->pNext = pNew;
                pNew->pNext = NULL;

                pTail = pNew;

        }
        pNode p = pHead;
        pTail->pNext = p->pNext;
        //pTail = p->pNext;
        free(p);
        p = NULL;
        return pTail;
}

void traverse_loop_list(pNode pRear)
{
        pNode p = pRear;
        pNode q = pRear->pNext;
        printf("%2d", p->data);
        while (p != q)
        {
                printf("%3d",q->data);
                q = q->pNext;
        }
        
        printf("\n");
}

/************************************************************************/
/* 在VS2013中程序运行如下:
请输入拉丁方阵的边数:n = 9

拉丁方阵如下:
1 2 3 4 5 6 7 8 9
2 3 4 5 6 7 8 9 1
3 4 5 6 7 8 9 1 2
4 5 6 7 8 9 1 2 3
5 6 7 8 9 1 2 3 4
6 7 8 9 1 2 3 4 5
7 8 9 1 2 3 4 5 6
8 9 1 2 3 4 5 6 7
9 1 2 3 4 5 6 7 8
请按任意键继续. . .                                                                     */
/************************************************************************/
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-12-6 21:11:30 | 显示全部楼层
xuexi
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2015-12-13 12:06:37 | 显示全部楼层
顶下小甲鱼~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2016-10-25 22:47:46 | 显示全部楼层
谢谢小甲鱼老湿
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-13 14:23:30 | 显示全部楼层
为什么我觉得第56行的    j--;   应该删掉
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-15 15:29:48 | 显示全部楼层
Latin方阵代码
#include<stdio.h>
#include<stdlib.h>

#define LEN sizeof(LinkList)

typedef struct node
{
        int data;
        struct node *next;
}LinkList;

LinkList *CreatList(int num) //生成循环链表
{
        int i;
        LinkList *head = NULL;
        LinkList *p,*s;
       
        for(i = 1; i <= num; i++)
        {
                s = (LinkList *)malloc(LEN);
                s->data = i;
               
                if(head == NULL)
                {
                        head = s;
                }
                else
                {
                        p->next = s;
                }
                p = s;
        }
        p->next = head;
        return head;
}

int main(void)
{
        LinkList *p;
        LinkList *s;
        int num;
        int i,j;
       
    printf("请输入想要创建的Latin维数:");
        scanf("%d",&num);
        p = CreatList(num);
        printf("  %d维Latin:\n",num);
       
        for(i=0; i < num; i++)
        {
                for(j=0; j < num; j++)
                {
                        printf("%3d",p->data);
                        p = p->next;
                }
                p = p->next;
                printf("\n");
        }
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

头像被屏蔽
发表于 2021-2-15 20:15:16 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-22 01:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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