重复值判断
来源:互联网 发布:搞笑视频软件下载 编辑:程序博客网 时间:2024/06/13 14:01
请设计一个高效算法,判断数组中是否有重复值。必须保证额外空间复杂度为O(1)。
给定一个int数组A及它的大小n,请返回它是否有重复值。
# 测试样例:[1,2,3,4,5,5,6],7返回:true
我的提交
# -*- coding:utf-8 -*-class Checker: def checkDuplicate(self, a, n): # write code here a = sorted(a) for i in range(len(a) - 1): if a[i] == a[i+1]: return True return False
参考答案
class Checker: def checkDuplicate(self, a, n): # write code here return len(set(a)) < n
import java.util.*;public class Checker { public boolean checkDuplicate(int[] a, int n) { if (a == null || n == 0) { return false; } heapSort(a); for (int i = 1; i < n; i++) { if (a[i] == a[i - 1]) { return true; } } return false; } public void heapSort(int[] arr) { for (int i = 0; i != arr.length; i++) { heapInsert(arr, i); } for (int i = arr.length - 1; i != 0; i--) { swap(arr, 0, i); heapify(arr, 0, i); } } public void heapInsert(int[] arr, int index) { while (index != 0) { int parent = (index - 1) / 2; if (arr[parent] < arr[index]) { swap(arr, parent, index); index = parent; } else { break; } } } public void heapify(int[] arr, int index, int heapSize) { int left = index * 2 + 1; int right = index * 2 + 2; int largest = index; while (left < heapSize) { if (arr[left] > arr[index]) { largest = left; } if (right < heapSize && arr[right] > arr[largest]) { largest = right; } if (largest != index) { swap(arr, largest, index); } else { break; } index = largest; left = index * 2 + 1; right = index * 2 + 2; } } public void swap(int[] arr, int index1, int index2) { int tmp = arr[index1]; arr[index1] = arr[index2]; arr[index2] = tmp; }}
阅读全文
0 0
- 重复值判断练习
- 重复值判断练习题
- 原地重复值判断
- 重复值判断
- 重复值判断
- 判断dataGridView是否重复值
- 判断数组重复的值 和重复个数
- HashMap怎样判断值是否重复
- sql server判断是否重复值
- 【刷题之路】重复值判断
- 如何判断JavaScript 数组含有重复值
- js判断数组是否有重复值
- String[] 数组判断值不能重复
- 如何判断主键重复
- funambol-重复项判断
- sql判断重复
- 判断是否重复登录
- 判断是否重复录入
- 排序
- Shortest Prefixes
- photoview拖拽和缩放
- Python学习(5)
- 技术路线的核心竞争力
- 重复值判断
- 递增数列最长(dp)
- spring boot之集成页面
- 模拟登陆豆瓣,发帖和回复code
- 使用Filter处理web中的表单提交过程中的中文问题
- Java 线程 50个Java多线程面试题
- FCC----------- Binary Agents
- pyCharm第三方库安装
- json与bean,beanlist互转