2019.07.24

作业里的程序题
1.输入一段字符串,无论是否有重复字母出现,都只打印出现过的小写字母,并按照小写字母顺序打印。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

void str(char *s)
{
    int i,j,k,m = 0;
    char t;
    char str1[100];
    
    for(i = 0;*(s+i) != '\0';i++)
    {
        for(j = i + 1;*(s+j) != '\0';j++)
        {
            if(*(s + i) > *(s + j))
            {
                t = *(s + i);
                *(s + i) = *(s + j);
                *(s + j) = t;
            }
        }
    }
    k = i;
    for(i = 0;i < k;i++)
    {
        if(s[i] != s[i + 1])
        {
            str1[m++] = s[i];
        }
        else
        {
            str1[m++] = s[i];
            i = i + 2;
        }
    }
    str1[m] = '\0';
    puts(str1);
}

int main()
{
    void str(char *s);
    char s[100] = {'\0'};
    char s1[100] = {'\0'};

    fgets(s,100,stdin);

    int i,j;
    i = 0;
    j = 0;

    while(s[i] != '\0')
    {
        if(s[i] >= 'a' && s[i] <= 'z')
        {
            s1[j++] = s[i++];
        }
        else
        {
            i++;
        }
        s1[j] = '\0';
    }
    str(s1);

    printf("\n");

    return 0;
}

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

#include <stdio.h>

int *getday(int *a,int week,int day)
{
    int *p;
     p = a + (week - 1) * 7 + day - 1;
     return p;
}

int main()
{
    int i;
    int week;
    int day;
    int a[31];
    int *p;

    p = NULL;

    for(i = 0;i < 31;i++)
    {
        a[i] = i + 1;
    }

    printf("input week and day:");
    scanf("%d%d",&week,&day);

    p = getday(a,week,day);

    printf("the day is : %d day\n",*p);

    return 0;
}

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

#include <stdio.h>
#include <stdlib.h>

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

typedef struct node Node;
typedef struct node *Link;

void create_link(Link *head)
{
    * head = NULL;
}

void is_malloc_ok(Link new_node)
{
    if(new_node == NULL)
    {
        printf("malloc error!\n");
        exit(-1);
    }
}

void create_node(Link *new_node)
{
    *new_node = (Link)malloc(sizeof(Node));
    is_malloc_ok(*new_node);
}

void insert_node_tail(Link *head,Link new_node)
{
    Link p;
    p = *head;

    if(*head == NULL)
    {
        *head = new_node;
        new_node -> next = NULL;
    }
    else
    {
        while(p -> next != NULL)
        {
            p = p -> next;
        }
        p -> next = new_node;
        new_node ->next = NULL;
    }
}

int find_node(Link *head,int b)
{
    Link p;
    p = *head;
    int i = 0;

    if(*head == NULL)
    {
        printf("link is empty!\n");
    }
    else
    {
        while(p -> num != b && p -> next != NULL)
        {
            i++;
            p = p -> next;
        }
        if((p -> next == NULL)&&(p -> num != b))
        {
            printf("can not find this number!\n");
            exit(-1);
        }
        else
        {
            return (i + 1);
        }
    }
}

void insert_node_mid(Link *head,Link new_node,int loc)
{
    Link p,q;
    p = q = *head;

    if((*head) -> num == loc)
    {
        new_node -> next = *head;
        *head = new_node;
    }
    else
    {
        while((p != NULL)&&p -> num != loc)
        {
            q = p;
            p = p -> next;
        }
        if(p == NULL)
        {
            q -> next = new_node;
            new_node -> next = NULL;
        }
        else
        {
            q -> next = new_node;
            new_node -> next = p;
        }
    }
}

void delete_node(Link *head,int d)
{
    Link p,q;
    p = q = *head;
    int i;

    if(*head == NULL)
    {
        printf("error!\n");
    }
    else
    {
        if(d == 1)
        {
            *head = p -> next;
            free(p);
        }
        else
        {
            for(i = 0;i < d - 1;i++)
            {
                q = p;
                p = p -> next;
            }

            q -> next = p -> next;
            free(p);
        }
    }
}

void release_link(Link *head)
{
    Link p;
    p = *head;
    while(*head != NULL)
    {
        *head = (*head) -> next;
        free(p);
        p = *head;
    }
}

void display_link(Link head)
{
    Link p;
    p = head;

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

    putchar('\n');
}

int main()
{
    int i;
    Link head;
    Link new_node;
    int a[10];
    int b;/*要查找的数*/
    int loc;
    int d;/*要删除的数*/

    create_link(&head);

    for(i = 0;i < 10;i++)
    {
        scanf("%d",&a[i]);
    }

    for(i = 0;i < 10;i++)
    {
        create_node(&new_node);
        new_node -> num = a[i];
        insert_node_tail(&head,new_node);
    }

    display_link(head);

    create_node(&new_node);
    
    printf("please input a number to find:");
    scanf("%d",&b);
    printf("the number is NO.%d\n",find_node(&head,b));

    printf("please input a number for new_node:");
    scanf("%d",&new_node -> num);

    printf("please input a number for insert location:");
    scanf("%d",&loc);

    insert_node_mid(&head,new_node,loc);
    
    puts("after inserting");

    display_link(head);

    printf("please input a number to delete:");
    scanf("%d",&d);

    delete_node(&head,d);

    puts("after deleting");

    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、付费专栏及课程。

余额充值