1218C语言练习

6 篇文章 0 订阅

输入某个月的第N周和这一周的第M天,通过int *GetDay() 函数获取参数并返回结果,来得出这一天是这个月的第多少天。(如输入:3,4,即这个月的第3周的第4天,即这个月的第18天)

#include <stdio.h>


int  *GetDay( int week , int day)
{
    int month = 0 ;
    month = week*7 + day;
    return month;
}

int main()
{
    int *p = NULL;
    int week ; 
    int day ; 
    printf("plz input week and days : \n");
    scanf("%d", &week);
    scanf("%d", &day);
    printf("the month is : %d\n", (*GetDay)(week , day));
    return 0;
}

(1)建立一个顺序表,要求从键盘输入10个整数,并将该顺序表的元素从屏幕显示出来;(2)用函数实现在顺序表中查找其中一个元素,如果找到,返回该元素在顺序表中的位置和该元素的值,否则提示无此元素;(3)用函数实现顺序表的插入和删除操作。由用户输入待插入元素及插入位置,将完成插入后的顺序表输出;由用户输入删除第几个元素,将完成删除后的顺序表输出。


#include <stdio.h>
#include<stdlib.h>
#define MAL_OK 1
#define MAL_ERR 0

struct node                
{
    int num;
    struct node *next; 
};

typedef struct node Node;
typedef struct node * Link;

void create_link(Link *head)           
    *head = (Link) malloc(sizeof(Node));
    (*head)->next = NULL;
}

void create_node(Link *new_node,int i)        
{
    do
    {
        *new_node = (Link)malloc(sizeof(Node));
    }while(judge_node(*new_node) == MAL_ERR);
    printf("num = %d\n" , i);
    (*new_node)->num = i;
    printf("newnum = %d\n", (*new_node)->num);
}

int judge_node(Link new_node)          
{
    if(new_node == NULL)
    {
        return MAL_ERR;
    }
    else
    {
        return MAL_OK;
    }
}

void insert_node_tail(Link head,Link new_node)
{
    Link p;
    p = head;
    if(head == NULL)
        printf("link is not found\n");
    else
    {
        while(p->next != NULL)
        {
            p = p->next;
        }
        p->next = new_node;
        new_node->next = NULL;
    }
}

void display_link(Link head)              
{
    Link p = NULL;
    p = head -> next;
    if(p == NULL)
    {
        printf("link is empty\n");
    }
    else
    {
        while(p != NULL)
        {
            printf("num = %d\n",p->num);
            p = p->next;
        }
    }
}

void release_link(Link head)    
    Link p;
    Link q;
    q = p = head -> next;
    if(p == NULL)
        printf("link is empty rel\n");
    else
        while(q != NULL)
        {
            q = q -> next;
            head -> next = q;
            free(p);
            p = head -> next;
        }
}

void del_node(Link head , int loc )
{
    Link p , q ;
    p = NULL;
    q = NULL;
    p = q = head -> next;
    if(NULL == p )
    {
        printf("Empty Link ! _del\n");
        return ;
    }
    while(loc != (p -> next) -> num);
    {
        p = p -> next;
        if(NULL == p -> next)
        {
            printf("Not find _del\n");
        }
        q = p -> next ;
        p = q -> next ;
        free(q);
    }
    return ;
}

void change_node(Link head , int loc ,int val)
{
    Link p = NULL;
    if( head -> next == NULL)
    {
        printf("Empty Link _change\n");
        return :
    }
    while(loc != p -> num)
    {
        p = p -> next;
        if(p -> next == NULL)
        {
            printf("Not Find\n");
            return ;
        }
    }
    p -> num = val;
    return ; 
}

int find_node(Link head , int loc)
{
    Link p = head -> next ;
    if( head -> next == NULL)
    {
        printf("Empty Link _change\n");
        return :
    }
    while(loc == (p -> num))
    {
        p = p -> next ;
        if(p -> next == NULL)
        {
            printf("Not Find\n");
            return ;
        }
        return p -> num;
    }
}
int main()
{
    Link head = NULL;
    Link new_node = NULL;
    int i;
    create_link(&head);
    for(i = 1;i < 10;i++)
    {
         create_node(&new_node,i);
         insert_node_tail(head,new_node);
        printf("afterinsert = %d\n",new_node -> num);
    }
    display_link(head);
    printf("\n");
    int loc , val;
    printf("plz input loc and val\n");
    scanf("%d",&loc);
    scanf("%d",&val);
    change_node(head , loc , val);
    desplay_link(head);
    printf("plz input loc to del\n");
    scanf("%d", &loc);
    del_node(head , loc);
    display_link(head);
    release_link(head);
    display_link(head);
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值