C语言经典例题-19

1.字符串左旋结果

题目内容:写一个函数,判断一个字符串是否为另外一个字符串旋转之后的字符串。

例:给定s1 = AABCD和s2 = BCDAA,返回1

给定s1 = abcd和s2 = ACBD,返回0

AABCD左旋一个字符得到ABCDA

AABCD左旋两个字符得到BCDAA

AABCD右旋一个字符得到DAABC

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

int is_string_left_rotate(char* str1, char* str2)
{
    int i = 0;
    int len = strlen(str1);
    for (i = 0; i < len; i++)
    {
        char tmp = *str1;
        int j = 0;
        for (j = 0; j < len - 1; j++)
        {
            *(str1 + j) = *(str1 + j + 1);
        }
        *(str1 + len - 1) = tmp;

        if (strcmp(str1, str2) == 0)
        {
            return 1;
        }
    }
    return 0;
}

int main()
{
    char arr1[10] = "AABCD";
    char arr2[10] = "BCDAA";
    int ret = is_string_left_rotate(arr1,arr2);
    if (ret == 1)
    {
        printf("YES\n");
    }
    else
        printf("NO\n");
    return 0;
}
2.offsetof宏的实现

写一个宏,计算结构体中变量相对于首地址的偏移

#include <stdio.h>

#define OFFSETOF(struct_name,mem_name) (int)&(((struct_name*)0)->mem_name)

struct A
{
    int a;
    short b;
    int c;
    char d;
};

int main()
{
    printf("%d\n", OFFSETOF(struct A, a));
    printf("%d\n", OFFSETOF(struct A, b));
    printf("%d\n", OFFSETOF(struct A, c));
    printf("%d\n", OFFSETOF(struct A, d));
    return 0;
}
3.模拟实现atoi
#include <stdio.h>
#include <limits.h>
#include <ctype.h>

enum State
{
    INVALID,
    VALID
};

enum State state = INVALID;

int my_atoi(const char* p)
{
    int flag = 1;
    if (p == NULL)
    {
        return 0;
    }
    if (*p == '\0')
    {
        return 0;
    }
    while (isspace(*p))
    {
        p++;
    }
    if (*p == '+')
    {
        flag = 1;
        p++;
    }
    else if (*p == '-')
    {
        flag = -1;
        p++;
    }

    long long n = 0;
    while (isdigit(*p))
    {
        n = n * 10 + flag * (*p - '0');
        if (n < INT_MIN || n>INT_MAX)
        {
            return 0;
        }
        p++;
    }
    if (*p == '\0')
    {
        state = VALID;
        return (int)n;
    }
    else
    {
        return (int)n;
    }
}

int main()
{
    const char* p = "   -14a";
    int ret = my_atoi(p);
    if(state == VALID)
        printf("合法:%d\n", ret);
    else
        printf("非法:%d\n", ret);
    return 0;
}
4.n的k次方

编写一个函数实现n的k次方,使用递归实现。

#include <stdio.h>

double Pow(int n, int k);

int main()
{
    int n = 0;
    int k = 0;
    scanf("%d %d", &n, &k);
    double ret = Pow(n, k);
    printf("%lf\n", ret);
    return 0;
}

double Pow(int n, int k)
{
    if (k == 0)
        return 1;
    else if (k > 0)
        return n * Pow(n, k - 1);
    else
        return 1.0 / (Pow(n, -k));
}
5.字符串逆序

编写一个函数reverse_string(char *string)

实现:将参数字符串中的字符反向排列,不是逆序打印。

要求:不能使用C函数库中的字符串操作函数。

比如:char arr[] = “abcdef”

逆序之后数组的内容变成:fedcba


相关推荐

  1. C语言经典例题-19

    2024-04-21 01:56:03       35 阅读
  2. C语言经典例题-19

    2024-04-21 01:56:03       21 阅读
  3. C语言经典例题-11

    2024-04-21 01:56:03       31 阅读
  4. C语言经典例题-12

    2024-04-21 01:56:03       42 阅读
  5. C语言经典例题-16

    2024-04-21 01:56:03       30 阅读
  6. C语言经典例题(27)

    2024-04-21 01:56:03       45 阅读
  7. C语言经典例题(3)

    2024-04-21 01:56:03       36 阅读
  8. C语言经典例题-20

    2024-04-21 01:56:03       41 阅读
  9. C语言经典例题-5

    2024-04-21 01:56:03       37 阅读
  10. C语言经典例题-2

    2024-04-21 01:56:03       36 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-21 01:56:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-21 01:56:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-21 01:56:03       82 阅读
  4. Python语言-面向对象

    2024-04-21 01:56:03       91 阅读

热门阅读

  1. 视频怎么去水印,轻松去视频水印的方法

    2024-04-21 01:56:03       31 阅读
  2. 服务器为什么要定期备份

    2024-04-21 01:56:03       38 阅读
  3. Linux at练习之在系统中设定延迟任务

    2024-04-21 01:56:03       36 阅读
  4. 【Android】 镜像及分区

    2024-04-21 01:56:03       32 阅读
  5. python-pdf的合并与拆分

    2024-04-21 01:56:03       39 阅读
  6. Lambda表达式学习

    2024-04-21 01:56:03       28 阅读
  7. springboot基础介绍

    2024-04-21 01:56:03       32 阅读
  8. selenium篇-基础用法

    2024-04-21 01:56:03       32 阅读
  9. MongoDB快速启动

    2024-04-21 01:56:03       35 阅读
  10. Stable Diffusion本地部署教程

    2024-04-21 01:56:03       35 阅读
  11. 戒烟生活记录

    2024-04-21 01:56:03       29 阅读
  12. Stable Diffusion 本地部署教程

    2024-04-21 01:56:03       42 阅读
  13. 如何在Python中处理图像和视频?

    2024-04-21 01:56:03       39 阅读