面试有关问题:给你一个文本文件,里面存储了一亿个QQ号,请用程序将其由小到大排序,汗呀!
面试问题:给你一个文本文件,里面存储了一亿个QQ号,请用程序将其由小到大排序,汗呀!..
面试问题:给你一个文本文件,里面存储了一亿个QQ号,请用程序将其由小到大排序,汗呀!..
求高手讲解思路!
还有其它问题:
比如Memcache的运行机制,它的工作原理它有什么优缺点!
现有一个库存100件的产品要进行秒杀,在秒杀过程中的秒杀人数远远超过库存,请问你将如何处理,应该注意什么问题!
请谈谈你对Mysql的优化的见解,或者说如果让你设计一个数据库,你将怎样设计并优化!
有高手吗,今天面试都自己认为都答得不太理想,求指教,还有下面的面试!
小弟的刚刚被裁员,本来就冬天,真的好冷啊!
------解决方案--------------------
排序的问题想不出来什么好办法,有没有更具体的限制条件,比如运行时间和内存?
如果都不限制直接sort函数就行,里面是用的快速排序法(quicksort),理论上的效率应该是最高的,况且人家是native code,怎么也比php代码里模拟一个排序算法快。
memcache的运行机制是使用职守进程开辟一块内存空间用来保存key/value数据,所有的请求和应用都共用这些数据。优点是存取速度快,适合用来缓存频繁读写的数据。缺点是占用内存,同时只能通过key检索,无法进行关系查询(SQL等)。
要保证原子操作,使用一定的锁机制防止多个请求同时操作一个数据造成效果与预期不符。
mysql数据库优化主要是索引和分表,为了性能可以为所有需要排序和检索的字段建立索引,并通过水平或垂直分表方式提高效率。
------解决方案--------------------
目的肯定不是让你投机,导入数据库,建索引导出,不过可以提一下
遍历一遍,将号码按大小,写入合适的文件。。。比如约定10万一个号码段
比如10,000,写在第0个文件,100,000,001,属于第1K个文件里面
排序每一个文件数据,拼接文件
排序的时候,如果文件较大,这里根据文件大小,大概能估计号码数量级的。。如果号码量少,可选择快排,否则,
创建一个10万的数组,再次遍历,arr[qqnum-i*100000]+1;
遍历数组,依数组值,增量写入号码即可
复杂度是O(n),O(nlogn)之间
------解决方案--------------------
这面试题有点眼熟啊,算法板块貌似讨论过,所以我回答用bitmap,空间换时间。
而且实际要做可能需要分段处理,比如5-7位的qq直接bit hash,7-10位的bit hash值 + 1000000
- PHP code
<?php set_time_limit(0); //5-7位qq $s = '0'; $s{9999999} = 1; $s{22334} = 1; $s{375345} = 1; $i = 10000; while(isset($s{$i})) { if($s{$i} == 1) echo "QQ:".$i."<br/>"; $i++; } ?> <br><font color="#e78608">------解决方案--------------------</font><br>
------解决方案--------------------

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

웹 개발에서는 웹사이트 성능과 응답 속도를 향상시키기 위해 캐싱 기술을 사용해야 하는 경우가 많습니다. Memcache는 모든 데이터 유형을 캐시할 수 있고 높은 동시성 및 고가용성을 지원하는 널리 사용되는 캐싱 기술입니다. 이 기사에서는 PHP 개발에 Memcache를 사용하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. Memcache 설치 Memcache를 사용하려면 먼저 서버에 Memcache 확장 프로그램을 설치해야 합니다. CentOS 운영 체제에서는 다음 명령을 사용할 수 있습니다.

이 글의 Redis 테스트 코드는 다음 환경을 기반으로 합니다. 운영 체제: MacOS 64비트 버전: Redis5.0.764bit 운영 모드: 독립형 모드 Redis 비트 연산 레이드 비트 연산은 비트 배열 연산이라고도 하며 비트맵 4가지 명령을 제공합니다. : SETBIT, GETBIT, BITCOUNT 및 BITTOP 이진 비트 배열을 조작하는 데 사용됩니다. 먼저 일련의 기본 작업 예제를 살펴보겠습니다. SETBIT 구문: SETBITkeyoffsetvalue는 명령 키 오프셋 0/1입니다. setbit 명령은 비트 배열에 지정된 오프셋의 이진 비트 설정 값을 쓰는 데 사용됩니다. 오프셋은 0부터 시작하여 계산됩니다. 쓰기 1 또는 0만 허용됩니다.

해시 연산 //해시 테이블의 필드에 값을 할당합니다. 성공하면 1을, 실패하면 0을 반환합니다. 해시 테이블이 없으면 테이블이 먼저 생성된 후 값이 할당됩니다. 필드가 이미 있으면 이전 값을 덮어씁니다. $ret=$redis->hSet('user','realname','jetwu');//해시 테이블에서 지정된 필드의 값을 가져옵니다. 해시 테이블이 없으면 false를 반환합니다. $ret=$redis->hGet('사용자','지역

Laravel은 현재 가장 인기 있는 PHP 웹 프레임워크 중 하나이며 개발자에게 많은 강력한 기능과 구성 요소를 제공하며 LaravelHash도 그 중 하나입니다. LaravelHash는 비밀번호를 안전하게 유지하고 애플리케이션의 사용자 데이터를 더욱 안전하게 만드는 데 사용할 수 있는 비밀번호 해싱용 PHP 라이브러리입니다. 이 글에서는 LaravelHash의 작동 방식과 이를 사용하여 비밀번호를 해시하고 확인하는 방법을 알아봅니다. 라라 학습을 위한 필수 지식

PHP 개발에서 효율적인 데이터 쓰기 및 쿼리를 위해 Memcache를 사용하는 방법은 무엇입니까? 인터넷 애플리케이션의 지속적인 개발로 인해 시스템 성능에 대한 요구 사항이 점점 더 높아지고 있습니다. PHP 개발에서는 시스템 성능과 응답 속도를 향상시키기 위해 다양한 캐싱 기술을 사용하는 경우가 많습니다. 일반적으로 사용되는 캐싱 기술 중 하나는 Memcache입니다. Memcache는 데이터베이스 쿼리 결과, 페이지 조각, 세션 데이터 등을 캐시하는 데 사용할 수 있는 고성능 분산 메모리 객체 캐싱 시스템입니다. 데이터를 메모리에 저장함으로써

PHP 개발에서 Memcache 캐싱 시스템을 사용하면 데이터 읽기 및 쓰기 효율성을 크게 향상시킬 수 있습니다. Memcache는 데이터베이스를 자주 읽고 쓰지 않도록 메모리에 데이터를 캐시할 수 있는 메모리 기반 캐싱 시스템입니다. 이 기사에서는 효율적인 데이터 읽기 및 쓰기 작업을 위해 PHP에서 Memcache를 사용하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. Memcache 설치 및 구성 먼저 서버에 Memcache 확장 프로그램을 설치해야 합니다. 합격할 수 있다

2025 년에 10 개의 가상 통화 거래 플랫폼 : 1. Binance; 사용자 경험 및 기타 요인에 가장 적합합니다.

CentOS는 RHEL에서 유래한 Linux 배포판으로, 오픈 소스 코드 규정에 따라 컴파일되었습니다. 또한 RHEL과의 기능적 호환성을 유지하며 사용자가 저작권 비용을 지불하지 않고 사용하고 수정할 수 있는 무료 오픈 소스 운영 체제입니다. 그러면 CentOS는 Linux에서 32비트와 64비트를 구분합니까? 자세한 내용은 아래를 참조하십시오. CentOS는 32비트와 64비트를 구별합니다! CentOS32비트 시스템은 주로 PC용으로 출시되며, CentOS64비트 시스템은 주로 64비트 하드웨어 시스템에 설치됩니다.
