【每日刷题】Day83

【每日刷题】Day83

🥕个人主页:开敲🍉

🔥所属专栏:每日刷题🍍

🌼文章目录🌼

1. LCR 192. 把字符串转换成整数 (atoi) - 力扣(LeetCode)

2. 415. 字符串相加 - 力扣(LeetCode)

3. 344. 反转字符串 - 力扣(LeetCode)

1. LCR 192. 把字符串转换成整数 (atoi) - 力扣(LeetCode)

//思路:遍历。

int myAtoi(char* str)

{

    long long ans = 0;

    int flag1 = 0;

    int flag2 = 0;

//跳过空白字符

    while(*str==' ')

    {

        str++;

    }

//判断为正数还是负数

    if(*str=='-')

    {

        flag1 = 1;

        flag2 = 1;

        str++;

    }

    else if(*str=='+')

        str++;

    while(*str!='\0'&&(*str>=48&&*str<=57))

    {

//如果为负数,则结果初始要为负

        if(flag1)

        {

            ans = ans-(*str-'0');

            flag1 = 0;

            str++;

            continue;

        }

//为负数则减去该位

        if(flag2)

        {

            if(ans*10<INT_MIN)

                return INT_MIN;

            ans = ans*10-(*str-'0');

        }

//为正数则加上该位

        else

        {

            if(ans*10>INT_MAX)

                return INT_MAX;

            ans = ans*10+(*str-'0');

        }

        str++;

    }

//控制结果在整型范围内

    if(ans>INT_MAX)

        ans = INT_MAX;

    if(ans<INT_MIN)

        ans = INT_MIN;

    return (int)ans;

}

2. 415. 字符串相加 - 力扣(LeetCode)

//思路:字符串存储+进位。

char * addStrings(char * num1, char * num2)

{

    int str1 = strlen(num1);

    int str2 = strlen(num2);

    int size_tmp = str1+2;

    if(str2>str1)

        size_tmp = str2+2;

//这里需要空出字符串0位置

    char* tmp = (char*)malloc(sizeof(char)*size_tmp);

    tmp[size_tmp-1] = '\0';

    int i = str1-1;

    int j = str2-1;

    int flag = 0;

    int tmpsize = size_tmp-2;

    while(i>=0||j>=0)

    {

//从后往前获取每一位

        int a = i>=0?(num1[i]-'0'):0;

        int b = j>=0?(num2[j]-'0'):0;

//位相加再加上进位标志再取模

        tmp[tmpsize--] = (a+b+flag)%10+'0';

        if(a+b+flag>=10)

            flag = 1;

        else

            flag = 0;

        if(i>=0)

            i--;

        if(j>=0)

            j--;

    }

    char* ans = (char*)malloc(sizeof(char)*10000);

    int count = 0;

//如果除了循环flag还为1,则说明进到最高位

    if(flag)

    {

        tmp[0] = '1';

        for(int i = 0;i<strlen(tmp);i++)

        {

            ans[count++] = tmp[i];

        }

    }

//否则,字符串0位置的值我们不计入结果

    else

    {

        for(int i = 1;i<strlen(tmp);i++)

        {

            ans[count++] = tmp[i];

        }

    }

    ans[count] = '\0';

    return ans;

}

3. 344. 反转字符串 - 力扣(LeetCode)

//思路:双指针。

void Swap(char* x,char* y)

{

    char tmp = *x;

    *x = *y;

    *y = tmp;

}


 

void reverseString(char* s, int sSize)

{

    int i = 0;

    int j = sSize-1;

    while(i<j)

    {

        Swap(&s[i],&s[j]);

        i++;

        j--;

    }

}

相关推荐

  1. 每日Day13

    2024-07-21 03:06:01       27 阅读

最近更新

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

    2024-07-21 03:06:01       52 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-21 03:06:01       54 阅读
  3. 在Django里面运行非项目文件

    2024-07-21 03:06:01       45 阅读
  4. Python语言-面向对象

    2024-07-21 03:06:01       55 阅读

热门阅读

  1. 栈的概念—函数调用

    2024-07-21 03:06:01       16 阅读
  2. 机器学习中的梯度下降

    2024-07-21 03:06:01       17 阅读
  3. Rollup介绍

    2024-07-21 03:06:01       16 阅读
  4. Windows图形界面(GUI)-DLG-C/C++ - 状态栏(StatusBar)

    2024-07-21 03:06:01       21 阅读
  5. 三角函数cos

    2024-07-21 03:06:01       13 阅读
  6. 【东耐设计】如何在C4D创作中激发无限创意?

    2024-07-21 03:06:01       15 阅读
  7. NLP基础技术

    2024-07-21 03:06:01       17 阅读
  8. MySQL 覆盖索引

    2024-07-21 03:06:01       19 阅读