【力扣C语言】每日一题

目录

【28题】

思路:

【171题】

思路:

【283题,移动零】

思路:


【28题】

思路:

先用strstr查看是否存在匹配项,再用strncmp比较是否和匹配项相同并输出下标。

复制代码
int strStr(char* haystack, char* needle) {
    char *p = strstr(haystack,needle);
    if(p==NULL)
    {
        return -1;
    }
    for (int i = 0; i < strlen(haystack); i++)
    {
        if(strncmp(needle,&haystack[i],strlen(needle))==0)
        {
            return i;
        }
    }
    return -1;
}

【171题】

思路:

(1)根据ascll码表,遍历每一位减64,使A=1;B=2...

(2)如果len大于等于1,for循环求结果,第i位(这里指按自然数的第i位,例如ABC,A为第三位,C位第一位。)应该等于26的(i-1)次方乘以该位上的数字。最后相加求和输出结果。

代码:

复制代码
int titleToNumber(char* columnTitle) {
    
    int len=strlen(columnTitle);
    for(int i = 0;i<len;i++)
    {
        columnTitle[i]-=64;
    }
    if(len>=1)
    {
        int sum = 0;
        int j=len-1; // j用来计算该位需要乘以多少个26.
        for(int i=0;i<len;i++)
        {
            sum+=columnTitle[i]*pow(26,j);
            j--;
        }
        return sum;
    }
    else
    {
        return -1;
    }
    return 0;
   
}

当然也可以将第一步与第二步结合

复制代码
int titleToNumber(char* columnTitle) {
    
    int len=strlen(columnTitle);
    if(len>=1)
    {
        int sum = 0;
        int j=len-1;
        for(int i=0;i<len;i++)
        {
            sum+=(columnTitle[i]-64)*pow(26,j);
            j--;
        }
        return sum;
    }
    else
    {
        return -1;
    }
    return 0;
   
}

【283题,移动零】

思路:

(1)将不是0的数移到最前方,并计数

(2)将后面数赋值为0,输出结果

复制代码
void moveZeroes(int* nums, int numsSize) {
    int right=0,left=0;
    int len=numsSize;
    while(numsSize--)
    {
        if(nums[left]==0)
        {
            left++;
        }
        else
        {
            nums[right]=nums[left];
            right++;
            left++;
        }
    }
    for(int i=right;i<len;i++)
    {
        nums[i]=0;
    }
    for(int i=0;i<len;i++)
    {
        printf("%d\t",nums[i]);
    }
}
相关推荐
꧁Q༒ོγ꧂1 分钟前
算法详解---大纲
算法
m0_603888717 分钟前
Scaling Trends for Multi-Hop Contextual Reasoning in Mid-Scale Language Models
人工智能·算法·ai·语言模型·论文速览
Xの哲學10 分钟前
Linux io_uring 深度剖析: 重新定义高性能I/O的架构革命
linux·服务器·网络·算法·边缘计算
comli_cn17 分钟前
残差链接(Residual Connection)
人工智能·算法
情缘晓梦.24 分钟前
C语言数据存储
c语言·开发语言
Aaron158824 分钟前
基于VU13P在人工智能高速接口传输上的应用浅析
人工智能·算法·fpga开发·硬件架构·信息与通信·信号处理·基带工程
予枫的编程笔记26 分钟前
【论文解读】DLF:以语言为核心的多模态情感分析新范式 (AAAI 2025)
人工智能·python·算法·机器学习
im_AMBER35 分钟前
Leetcode 99 删除排序链表中的重复元素 | 合并两个链表
数据结构·笔记·学习·算法·leetcode·链表
王老师青少年编程1 小时前
信奥赛C++提高组csp-s之欧拉回路
c++·算法·csp·欧拉回路·信奥赛·csp-s·提高组
墨有6661 小时前
数学分析栈的出栈顺序:从算法判断到数学本质(卡特兰数初探)
c++·算法·数学建模