Remove Duplicates from Sorted List 删除链表中的重复元素,保留一次

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode *deleteDuplicates(ListNode *head) {
        // IMPORTANT: Please reset any member data you declared, as
        // the same Solution instance will be reused for each test case.
        ListNode *curr=head;
        ListNode *prev=NULL;
        while(curr)
        {
            if(!prev)
            {
                prev=curr;
            }
            else if(prev->val!=curr->val)
            {
                prev->next=curr;
                prev=prev->next;
            }
            curr=curr->next;
        }
     if(prev)  prev->next=NULL;
       return head;
 }
};
删除数组重复元素,可以使用C语言编写一个算法来实现。具体的步骤如下: 1. 定义一个函数,接收一个整型数组和数组的大小作为参数。 2. 在函数内部,创建一个新的数组,并将原数组的第一个元素存入新数组。 3. 使用两个嵌套的for循环来遍历原数组。外层循环用于迭代原数组的每个元素,内层循环用于比较当前元素与新数组元素是否相同。如果相同,则跳过此元素;否则,将该元素添加到新数组。 4. 返回新数组。 下面是一个示例代码实现: ```c #include <stdio.h> int* removeDuplicates(int arr[], int size) { int* newArr = (int*)malloc(size * sizeof(int)); int newSize = 1; // 新数组的大小,默认为1,即保留原数组的第一个元素 newArr[0] = arr[0]; // 将原数组的第一个元素存入新数组 for (int i = 1; i < size; i++) { int isDuplicate = 0; for (int j = 0; j < newSize; j++) { if (arr[i] == newArr[j]) { isDuplicate = 1; break; } } if (isDuplicate == 0) { newArr[newSize] = arr[i]; newSize++; } } return newArr; } int main() { int arr[] = {1, 2, 3, 4, 2, 3, 5, 6, 1}; int size = sizeof(arr) / sizeof(arr[0]); int* newArr = removeDuplicates(arr, size); printf("原数组:"); for (int i = 0; i < size; i++) { printf("%d ", arr[i]); } printf("\n删除重复元素后的数组:"); for (int i = 0; i < newSize; i++) { printf("%d ", newArr[i]); } free(newArr); // 释放内存 return 0; } ``` 这段代码将会输出: ``` 原数组:1 2 3 4 2 3 5 6 1 删除重复元素后的数组:1 2 3 4 5 6 ``` 通过该算法,我们可以删除数组重复元素,并保留一个。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值