之前已经学会了单链表的建立删除插入转置以及一些普通操作,双链表和单链表差不多,就是多了一个前驱指针,在许多操作中很方便,但是加了一个指针开销应该会大一些,总体上影响不大,这里开始讨论循环链表以及其他的一些数据结构. 1.已知n个人(以编号1,2,3,...,n分别表示)围坐在一张圆桌周围,从编号为k的人开始报数,数到m的那个人出列,他的下一个人又从k开始报数,数到m的那个人出列,依次重复下去,直到圆桌的人全部出列.试用C++编写实现. 解析:本题就是约瑟夫环问题的实际场景,要通过输入n.m.k三…
数据结构:栈 队列: 堆: 固定尺寸的数组:…
本文是根据慕课网Jason老师的课程进行的PHP面试知识点总结和升华,如有侵权请联系我进行删除,email:guoyugygy@163.com 在面试中,考官往往喜欢基础扎实的面试者,而函数相关的考点,往往是大家容易忽视的一个点,今天冷月就来帮各位小伙伴们梳理一下,在面试中函数相关的注意点. 回顾真题 <?php /** * Created by 冷月小白. * 微信公众号: 学长冷月 */ $count = 5; function get_count() { static $count; re…
前期调试 我的程序代码是: 首先,用gcc g gdb.c -o gdb -m32产生32位汇编. 输入gdb gdb进入gdb调试器 在main函数处设置一个断点:b main 用disassemble指令获取汇编代码 输入i r查看个寄存器的值 输入display /i $pc,这样在每次执行下一条汇编语句时,都会显示出当前执行的语句.下面展示每一步时%esp.%ebp和堆栈内容的变化 用si.i r.x/na %esp指令对每一步进行分析 输入si执行一步 调用f函数 输入i r看寄存器的…
最近在复习面试相关的知识点,然后做笔记,后期(大概在2018.02.01)会分享给大家,尽自己最大的努力做到最好,还希望到时候大家能给予建议和补充 ----------------2018.03.05------------------- 原本说好的2月份写出,但是因为知识点太多,就跳票了.... ----------------2018.04.03------------------- 今天终于有时间来整理这些笔记,然后将他们整理分类分成几个不同的模块,这样大家看起来也更方便些,以后会慢慢来完…
学习中的一些牢骚.栈/堆地址标准写法. 2017-02-12 • 杂谈 • 暂无评论 • 老衲 •浏览 226 次 我一直都在寻找各种业务功能的最简单写法,用减法的模式来开发软件.下面是我的写法,如果有更简单的方法,请留言告知. 本人再学习的过程中,遇到很多难题,delphi很多地方自身的设计就很乱.比如对参数修饰符的理解,网上100篇文章 90篇都有问题 错误率非常高.delphi 的数据类型有很多同一个参数修饰符 修饰 不同数据类型 的意义都是有差异的.你或许认为你知道 传值与传址:传址 又…
本文是根据慕课网Jason老师的课程进行的PHP面试知识点总结和升华,如有侵权请联系我进行删除,email:guoyugygy@163.com 在面试中,考官往往喜欢基础扎实的面试者,而运算符相关的考点,往往是大家容易忽视的一个点,今天冷月就来帮各位小伙伴们梳理一下,在面试中运算符相关的注意点. 回顾真题 abc()和@abc()之间的区别. 答案:PHP 支持一个错误控制运算符:@.当将其放置在一个 PHP 表达式之前,该表达式可能产生的任何错误信息都被忽略掉.使用方法如下: <?php /*…
本文是根据慕课网Jason老师的课程进行的PHP面试知识点总结和升华,如有侵权请联系我进行删除,email:guoyugygy@163.com 面试是每一个PHP初学者到PHP程序员必不可少的一步,冷月将为大家对PHP基础知识:JS.JQuery.AJAX:Linux:MySQL:程序设计题:PHP框架:算法.逻辑思维:高并发解决方案等做一个全方位的解析. 回顾真题 PHP中字符串可以使用哪三种定义方式以及各自的区别是什么? 答案: 单引号 双引号 heredoc()和newdoc() 先来看看…
最近收到一位粉丝的回馈! 这位粉丝已经成功入职阿里了小编很是羡慕啊! 今天就把这份30w字Java面试笔记给大家分享出来,说来也巧这份资料也是由一位阿里技术官整理出来的这算不算是"搬起石头砸自己的脚呢"哈哈! Java面试笔记 这份资料的内容非常全面而且细致入微,有Java入门,基础,字符串,进阶,项目,虚拟机,数据库,微服务,算法,并发,线程,集合,Linux,面试题等等Java相关技术点,希望你能凭借这份资料剑指offer! 内容总览: Java基础篇(45道面试题) 字符串&am…
Java内存分析--栈--堆 JVM的内存分析: 1.栈内存 1.连续的存储空间,遵循后进先出的原则. 2.每个线程包含一个栈区,栈区只保存基础数据类型的对象和自定义对象的引用. 3.每个栈中的数据都是私有的,其他栈不能访问 4.栈空间较小,用完立刻清理 2.堆内存 1.不连续的空间,用于存放new出的对象,或者说是类的实例. 2..JVM只有一个堆区被所有线程共享 3.空间较大.垃圾回收器回收垃圾 3.方法区 方法区在堆空间内,用于存放: 1.类内代码信息: 2.静态变量和方法: 3.常量池(…
栈: Stack<int>  xt=new Stack<int>() ; 先进后出,后进先出,水杯结构,顺序表类似 常用方法:   .pop---->出栈,弹栈                    .Push---->压栈,进栈                    .peek---->获取栈顶元素                    .toArry---->转化数组,遍历      int[] ints= stack.ToArray();   Cons…
优先级队列 一.PriorityQueue PriorityQueue是优先级队列,它实现了Queue接口,它的队列长度 没有限制,与一般队列的区别是,它有优先级概念,每个元素都有优先 级,队头的元素永远都是优先级最高的.PriorityQueue内部是用堆实现的. 一.基本用法 主要构造方法: public PriorityQueue() public PriorityQueue(int initialCapacity, Comparator<? super E> comparator) p…
循环队列 非常好的数据结构,充分利用率空间,可以用于网络端存储socket消息! /*************************************** 作者: 未闻花语 版本: v1.0 最后修改时间: 2018/05/21 电话: 159****7727 功能&使用方法: * 泛型循环队列 * 1.计算使用大小 和 空间是否满的方法很是巧妙可以多加留意 * 2.我使用的循环队列和传统(即汇众老曾的循环队列表不同), * 具体请见<大话数据结构>,永远都会有至少一个空间,目…
8.java 线程     1)线程概念,线程与进程      线程:线程是“进程”中某个单一顺序的控制流.也被称为轻量进程.线程是进程中的实体,一个进程可以拥有多个线程,一个线程必须有一个父进程.线程不拥有系统资源,只有运行必须的一些数据结构:它与父进程的其它线程共享该进程所拥有的全部资源.进程可以创建和撤消线程,从而实现程序的并发执行. 进程:进程是操作系统结构的基础:是一个正在执行的程序:计算机中正在运行的程序实例:可以分配给处理器并由处理器执行的一个实体:由单一顺序的执行显示,一个当前状…
这些东西有点烦,有点无聊.如果要去C++面试就看看吧.几年前网上搜索的.刚才看到,就整理一下,里面有些被我改了,感觉之前说的不对或不完善. 1.求下面函数的返回值( 微软) int func(x)  {  int countx =0;  while(x)  {  countx ++;  x = x&(x-1);  }  return countx;  } 假定x = 9999. 答案:8 思路:将x转化为2进制,看含有的1的个数. 2. 什么是“引用”?申明和使用“引用”要注意哪些问题? 答:引…
点餐 做菜 Stack and Heap 堆和栈的区别 - Grandyang - 博客园 https://www.cnblogs.com/grandyang/p/4933011.html 在和计算机内存打交道时,我们一定会碰到堆和栈,这两个东西很容易搞混,那么现在就来梳理一下二者的关系. 栈是用来静态分配内存的而堆是动态分配内存的,它们都是存在于计算机内存之中. 栈的分配是在程序编译的时候完成的,直接存储在内存中,接触内存很快.栈是后进先出的顺序,最后被申请的块最先被释放,这样就很容易跟踪到栈…
小结: 1.栈内存 为什么快? Due to this nature, the process of storing and retrieving data from the stack is very fast as there is no lookup required, you just store and retrieve data from the topmost block on it. 堆内存 慢于栈内存 ,但存储空间动态,使用指针访问 Heap is used for dynam…
Php错误处理 Php错误级别: E_ERROR 致命错误,会终止脚本运行.值为1 E_WARNING 警告错误,给出提示,不会终止运行值为2 E_PARSE 编译时的语法解析错误,解析错误仅仅由分析器产生.值为4 E_NOTICE 运行时通知错误,表示脚本可能会遇到错误的情况 值为8 E_CORE_ERROR 在PHP初始化启动过程中发生的致命错误.该错误类似 E_ERROR,但是是由PHP引擎核心产生的. 值为16 E_CORE_WARNING PHP初始化启动过程中发生的警告 (非致命错误…
栈和队列 全文概览 基础知识 栈 栈是一种先进后出的数据结构.这里有一个非常典型的例子,就是堆叠盘子.我们在放盘子的时候,只能从下往上一个一个的放:在取的时候,只能从上往下一个一个取,不能从中间随意取出. 栈是一种操作受限的线性表,只允许在一端处理数据.主要包括两种操作,即入栈和出栈,也就是在栈顶插入一个数据和从栈顶删除一个数据. 栈既可以用数组实现,也可以用链表来实现.用数组实现的栈,我们叫作顺序栈,用链表实现的栈,我们叫作链式栈. 队列 队列是一种先进先出的数据结构.你可以把它想象成排队买票…
引言 本篇文章主要介绍.NET中6个重要的概念:栈,堆,值类型,引用类型,装箱,拆箱.文章开始介绍当你声明一个变量时,编译器内部发生了什么,然后介绍两个重要的概念:栈和堆:最后介绍值类型和引用类型,并说明一些有关它们的重要原理. 最后通过一个简单的示例代码说明装箱拆箱带来的性能损耗. 声明变量的内部机制 在.NET程序中,当你声明一个变量,将在内存中分配一块内存.这块内存分为三部分:1,变量名:2,变量类型:3,变量值. 下图揭示了声明一个变量时的内部机制,其中分配的内存类型依据你的变量类型..…
queue (队列) 队列是为线程安全使用的. 1.先入先出 import queue #测试定义类传入队列 class Foo(object): def __init__(self,n): self.n = n ) ) ),timeout=) # 超时时间后,抛出队列full异常 , , ],timeout=) print(new.full()) #判断队列是否满 True #) #队列已满,再放报错 print(new.qsize()) # 查看当前队列长度 print(new.get())…
内存管理: 栈区 [stack]:由编译器自动分配并释放,一般存放函数的参数值,局部变量等 堆区 [heap]:由程序员分配和释放,如果程序员不释放,程序结束时,可能会由操作系统回收 全局区(静态区) [static]:全局变量和静态变量的存储是放在一起的,初始化的全局变量和静态变量存放在一块区域,未初始化的全局变量和静态变量在相邻的另一块区域,程序结束后由系统释放 文字常量区:存放常量字符串,程序结束后由系统释放 程序代码区:存放函数的二进制代码 官方文档: 在iOS开发中: 一. 内存分析…
1. 程序计数器 线程私有 当前线程所执行的字节码的行号指示器 2. 虚拟机栈 线程私有 存:Java方法(局部变量表(基本数据类型).操作数栈.动态链栈.方法出口) StackOverflowError 栈深度大于虚拟机所允许的深度 OutOfMemoryError 无法满足内存分配 3. 本地方法栈 线程私有 与虚拟机栈相似 StackOverflowError 栈深度大于虚拟机所允许的深度 OutOfMemoryError 无法满足内存分配 4. 堆 线程共享 存:对象实例,新生代 老年代…
一.算法 1.归并排序 2.快速排序 3.算法复杂度 4.哈希表数据结构 二.数据库 1.设计一个用户关注系统的数据库表 1.设计一个用户关注系统的数据库表,写三个相关的SQL语句两张表,一张user表,一张relation表 # 建立user表 ) not null) # 建立relation表:uid--用户ID,rid--用户关注的人ID create table relation(uid int not null,rid int not null) # 1.查询用户a关注的人 selec…
数据库 1.将name字段添加索引 create index index_emp_name on student(name); 2.查询女生中数学成绩最高的分数 select max(score) from student where sex='女' and subject='数学' 3.查询男生中平均成绩最高的姓名 select name,avg(score) from student where sex='男' group by name having avg(score) >= all(s…
20. 浅拷贝与深拷贝 如何理解C++中的浅拷贝与深拷贝 深拷贝和浅拷贝 在进行对象拷贝时,当对象包含对其他资源的引用,如果需要拷贝这个独享所引用的对象,那就是深拷贝,否则就是浅拷贝 *** 21.构造函数和析构函数的调用顺序? 继承时需要注意的问题 构造函数是自上而下调用,析构函数是自下而上调用 顺序 #include<iostream> using namespace std; class Base{ public: Base(){cout<<"创建Base基类.&q…
一.偏函数(partial) ①第一种 结果为: ② 第二种 二.线程安全 将空间转换成时间 问题: 1秒钟打印所有结果 threading.current_thread().ident :线程ID ①不安全示例 import time from threading import Thread import threading class Foo(object): pass foo = Foo() def add(i): foo.num = i time.sleep() print(foo.nu…
垃圾JDK啊 Deque这个接口,既承担着FIFO的任务,即队列,也承担着LIFO的任务,即栈 目前jdk里面实现了这个接口的类有两个,一个是ArrayDeque,另一个是LinkedList 但是由于Deque违反了单一职责原则,所以使用时要小心.分清楚队列和栈各自的方法 http://chengfeng96.com/blog/2018/01/20/Java%E4%B8%AD%E7%94%A8Deque%E6%8E%A5%E5%8F%A3%E4%BB%A3%E6%9B%BFStack%E6%8…
引言 本篇文章主要介绍.NET中6个重要的概念:栈,堆,值类型,引用类型,装箱,拆箱.文章开始介绍当你声明一个变量时,编译器内部发生了什么,然后介绍两个重要的概念:栈和堆:最后介绍值类型和引用类型,并说明一些有关它们的重要原理. 最后通过一个简单的示例代码说明装箱拆箱带来的性能损耗. 声明变量的内部机制 在.NET程序中,当你声明一个变量,将在内存中分配一块内存.这块内存分为三部分:1,变量名:2,变量类型:3,变量值. 下图揭示了声明一个变量时的内部机制,其中分配的内存类型依据你的变量类型..…
电话面试中写C++,逻辑比较清楚的一个题目,一紧张就不能好好地写下来,漏洞百出.以前经常在完善的编译环境中写代码,换了一个白板子上写反而写的不通顺了,犯了一些基础错误,比如stack中的首个元素是top方法,判断是否为空为empty方法,方法名字写错了……以后看来还是要勤加练习才好.废话不多说,直接看题目了. 题目:两个数组,长度相同,都为n,两个数组分别为inseq和outseq,求出如果以inseq为入栈顺序,那么outseq可不可能是它的一个出栈顺序,可能则返回true 样例: inseq…