C语言 指针练习

1. 输入5个数(含负数、小数)将它们按由小到大的顺序排列起来

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

void sort(char *a[], int length)
{
        int i, j;
        char *tmp;

        for (i = 1; i <= length - 1; i++)
        {
                for (j = 1; j <= length - i - 1; j++)
                {
                        //if (strcmp(a[j + 1], a[j]) < 0)
                        if ((atof(a[j + 1]) - atof(a[j])) < 0)
                        {
                                tmp = a[j + 1];
                                a[j + 1] = a[j];
                                a[j] = tmp;
                        }
                }
        }
}

void print(char *a[], int length)
{
        int i;
        for (i = 1; i < length; i++)
        {
                printf("%s ", a[i]);
        }
        printf("\n");
}

int main(int argc, char *argv[])
{
        int i, j, tmp;
        int length = argc;

        sort(argv, length);

        print(argv, length);

        return 0;
}

atoi ( ) 函数是将字符串转换成浮点型

运行结果:

[root@localhost 0728]# ./103 -4 3 -7.1 -7.3 -7.2
-7.3 -7.2 -7.1 -4 3 

 

2. 字符串逆序函数

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

void string_reverse(const char *ptr, char *str)
{
    int len = strlen(ptr), i;

    ptr += (len - 1);

    for (i = 0; i < len; i++)
    {
        *str = *ptr;
        str++;
        ptr--;
    }
}

int main()
{
    char *ptr = (char *)malloc(sizeof(char) * 64);
    char *str = (char *)malloc(sizeof(char) * 64);

    printf("Please input:\n");
    scanf("%s", ptr);

    string_reverse(ptr, str);

    printf("%s\n", str);

    return 0;
}

3. 计算字符串中子串出现的次字数

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

int main()
{
    int len_str, len_ptr, i, num = 0;
    char *str = (char *)malloc(sizeof(char) * 32);
    char *ptr = (char *)malloc(sizeof(char) * 32);

    printf("Please input :\n");
    scanf("%s%s", str, ptr);

    len_str = strlen(str);
    len_ptr = strlen(ptr);

    if (len_str < len_ptr)
    {
        printf("input error!\n");
        return -1;
    }

    for (i = 0; i < len_str - len_ptr + 1; i++)
    {
        if (strncmp(str + i, ptr, len_ptr) == 0)
        {
            num++;
        }

        if (i == len_str)
        {
            printf("%s 不是 %s 的子串\n", ptr, str);
        }
    }

    if(num != 0)
    {
        printf("%s 共出现 %d 次\n", ptr, num);
    }

    return 0;
}


 

  • 1
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值