【每日刷题】Day25

2024-04-26 22:52
文章标签 每日 刷题 day25

本文主要是介绍【每日刷题】Day25,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【每日刷题】Day25

🥕个人主页:开敲🍉

🔥所属专栏:每日刷题🍍

🌼文章目录🌼

1. 238. 除自身以外数组的乘积 - 力扣(LeetCode)

2. 82. 删除排序链表中的重复元素 II - 力扣(LeetCode)

3. 445. 两数相加 II - 力扣(LeetCode)

1. 238. 除自身以外数组的乘积 - 力扣(LeetCode)

//思路:使用两个数组,分别存储左边元素的乘积和、右边元素的乘积和,在使用一个数组,存储这两个数组的每个位置元素的和。

int* productExceptSelf(int* nums, int numsSize, int* returnSize)

{

    int * ans = (int*)malloc(sizeof(int)*numsSize);

    int left[numsSize];//用于存储左边元素乘积和

    int right[numsSize];//用于存储右边元素乘积和

    int i = 0;

    left[0] = 1;

    for(i = 1;i<numsSize;i++)//计算原数组各个位置左边元素乘积

    {

        left[i] = left[i-1]*nums[i-1];

    }

    right[numsSize-1] = 1;

    for(i = numsSize-2;i>=0;i--)//计算原数组各个位置右边元素乘积

    {

        right[i] = right[i+1]*nums[i+1];

    }

    for(i = 0;i<numsSize;i++)

    {

        ans[i] = left[i]*right[i];//相加则是原数组各个位置除自身以外的元素乘积和

    }

    *returnSize = numsSize;

    return ans;

}

2. 82. 删除排序链表中的重复元素 II - 力扣(LeetCode)

//思路:哈希。这题由于链表中的元素存在小于0的,因此使用哈希时需要将小于0的数处理为>0的数。因为数据范围为-100~100,因此,可以将<0的数+201,将数据范围改为0~200,这样就可以使用哈希来解决。

typedef struct ListNode LN;

struct ListNode* deleteDuplicates(struct ListNode* head)

{

    if(head==NULL)

    {

        return NULL;

    }

    if(head->next==NULL)

    {

        return head;

    }

    int hash[1000] = {0};

    LN* pmove = head;

    while(pmove)

    {

        if(pmove->val<0)

        {

            pmove->val+=201;//将链表中小于0的数处理为>100的数

        }

        hash[pmove->val]+=1;//计算数据出现的次数

        pmove = pmove->next;

    }

    LN* Sentry = (LN*)malloc(sizeof(LN));//新链表用于接收只出现一次的数

    Sentry->next = NULL;

    LN* newhead = Sentry;

    if(head->val>100)//这里需要考虑链表中是否存在小于0的数,如果存在,则新链表接收数据的顺序需要相应改变

    {

        for(int i = 101;i<=200;i++)//先将<0的数存入新链表

    {

        if(hash[i]==1)//==1说明数据只出现了一次,存入新链表

        {

        LN* newnode = (LN*)malloc(sizeof(LN));

        newnode->next = NULL;

        newnode->val = i-201;

        newhead->next = newnode;

        newhead = newhead->next;

        }

    }

    for(int i = 0;i<=100;i++)//再存入>0的数

    {

        if(hash[i]==1)

        {

        LN* newnode = (LN*)malloc(sizeof(LN));

        newnode->next = NULL;

        newnode->val = i;

        newhead->next = newnode;

        newhead = newhead->next;

        }

    }

    }

    else

    {

        for(int i = 0;i<=100;i++)//链表中不存在<0的数则直接存储即可

        {

            if(hash[i]==1)

            {

                LN* newnode = (LN*)malloc(sizeof(LN));

                newnode->next = NULL;

                newnode->val = i;

                newhead->next = newnode;

                newhead = newhead->next;

            }

        }

    }

    return Sentry->next;

}

3. 445. 两数相加 II - 力扣(LeetCode)

//思路:使用两个数组arr1、arr2分别存储l1和l2的val。然后分别从后往前遍历数组相加存储进数组arr中,步骤和67. 二进制求和 - 力扣(LeetCode)//一致。最后再创建一个新链表,将数组arr中的数据存储进新链表返回

typedef struct ListNode LN;


 

int max(int x,int y)

{

    return x>y?x:y;

}

struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2)

{

    LN* Sentry = (LN*)malloc(sizeof(LN));//新链表的哨兵位

    Sentry->next = NULL;

    LN* newhead = Sentry;

    int i = 0;

    int j = 0;

    int arr1[100] = {0};

    int arr2[100] = {0};

    int arr[101] = {0};

    LN* pmove1 = l1;

    LN* pmove2 = l2;

    int flag = 0;

    while(pmove1)//将l1的val存进arr1

    {

        arr1[i++] = pmove1->val;

        pmove1 = pmove1->next;

    }

    while(pmove2)//将l2的val存进arr2

    {

        arr2[j++] = pmove2->val;

        pmove2 = pmove2->next;

    }

    i--;//定位到数组的最后一个元素

    j--;

    int max1 = max(i,j);//用于判断arr数组中存储数据的长度,arr0下标的位置需要空出来

    int max2 = max1;

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

    {

        int x = (i>=0)?arr1[i]:0;

        int y = (j>=0)?arr2[j]:0;

        arr[max2+1] = (x+y+flag)%10;//max2+1能够保证arr中0位置空出,并且存储进arr1、arr2相加后的数

        if(x+y+flag>=10)

        {

            flag = 1;

        }

        else

        {

            flag = 0;

        }

        max2--;

        if(i>=0)

        {

            i--;

        }

        if(j>=0)

        {

            j--;

        }

    }

    if(flag)//如果出了循环flag还为1,说明最高位也进了位,将arr数组0位置处的元素置为1

    {

        arr[0] = 1;

        for(i = 0;i<=max1+1;i++)//从arr数组0位置开始将数据存入新链表

    {

        LN* newnode = (LN*)malloc(sizeof(LN));

        newnode->next = NULL;

        newnode->val = arr[i];

        newhead->next = newnode;

        newhead = newhead->next;

    }

    }

    else

    {

        for(i = 1;i<=max1+1;i++)//如果flag为0,则说明最高位没有进1,则直接从arr数组1位置开始存入

    {

        LN* newnode = (LN*)malloc(sizeof(LN));

        newnode->next = NULL;

        newnode->val = arr[i];

        newhead->next = newnode;

        newhead = newhead->next;

    }

    }

    return Sentry->next;

}

这篇关于【每日刷题】Day25的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/938882

相关文章

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

每日一练7:简写单词(含链接)

1.链接 简写单词_牛客题霸_牛客网 2.题目 3.代码1(错误经验) #include <iostream>#include <string>using namespace std;int main() {string s;string ret;int count = 0;while(cin >> s)for(auto a : s){if(count == 0){if( a <=

【每日刷题】Day113

【每日刷题】Day113 🥕个人主页:开敲🍉 🔥所属专栏:每日刷题🍍 🌼文章目录🌼 1. 91. 解码方法 - 力扣(LeetCode) 2. LCR 098. 不同路径 - 力扣(LeetCode) 3. 63. 不同路径 II - 力扣(LeetCode) 1. 91. 解码方法 - 力扣(LeetCode) //思路:动态规划。 cl

hot100刷题第1-9题,三个专题哈希,双指针,滑动窗口

求满足条件的子数组,一般是前缀和、滑动窗口,经常结合哈希表; 区间操作元素,一般是前缀和、差分数组 数组有序,更大概率会用到二分搜索 目前已经掌握一些基本套路,重零刷起leetcode hot 100, 套路题按套路来,非套路题适当参考gpt解法。 一、梦开始的地方, 两数之和 class Solution:#注意要返回的是数组下标def twoSum(self, nums: Lis

代码随想录打卡Day25

今天一整天都在教研室做实验,没时间刷题,就做了一题,剩下的明天补 491.递增子序列 这道题目和之前的子集问题很像,但是有一点要注意的,这个输入的数组不能进行排序,所以就不能沿用之前的去重逻辑,这道题要去重还是得借助额外的变量来维护元素使用情况,但是这题的used为集合,且不能为全局变量,只能为树层遍历前定义的一个局部变量,除了这个改动以外,其他地方都是高度相似的。 class Soluti

力扣 739. 每日温度【经典单调栈题目】

1. 题目 理解题意: 1.1. 给一个温度集合, 要返回一个对应长度的结果集合, 这个结果集合里面的元素 i 是 当前 i 位置的元素的下一个更高温度的元素的位置和当前 i 位置的距离之差, 若是当前元素不存在下一个更高温度的元素, 则这个位置用0代替; 2. 思路 本题用单调栈来求解;单调栈就适用于来求当前元素左边或者右边第一个比当前元素大或者小的元素;【单调栈:让栈中的元素保持单调

代码随想录刷题day25丨491.递增子序列 ,46.全排列 ,47.全排列 II

代码随想录刷题day25丨491.递增子序列 ,46.全排列 ,47.全排列 II 1.题目 1.1递增子序列 题目链接:491. 非递减子序列 - 力扣(LeetCode) 视频讲解:回溯算法精讲,树层去重与树枝去重 | LeetCode:491.递增子序列_哔哩哔哩_bilibili 文档讲解:https://programmercarl.com/0491.%E9%80%92%E

每日一题——第八十一题

打印如下图案: #include<stdio.h>int main() {int i, j;char ch = 'A';for (i = 1; i < 5; i++, ch++){for (j = 0; j < 5 - i; j++){printf(" ");//控制空格输出}for (j = 1; j < 2 * i; j++)//条件j < 2 * i{printf("%c", ch

每日一题,力扣leetcode Hot100之238.除自身以外数组的乘积

乍一看这个题很简单,但是不能用除法,并且在O(N)时间复杂度完成或许有点难度。 考虑到不能用除法,如果我们要计算输出结果位置i的值,我们就要获取这个位置左边的乘积和右边的乘积,那么我新设立两个数组L和R。 对于L来说,由于表达的是位置i左边的数的乘积,那么L[0]=1,因为第一个数字左边没数那么为了不影响乘积初始值就设置为1,那么L[1]=L[0]*nums[0],那么L[i]=L[i-1