- 程序员代码面试指南刷题--第四章.换钱的方法数
一年而已
程序员代码面试指南刷题
题目描述给定数组arr,设数组长度为n,arr中所有的值都为正整数且不重复。每个值代表一种面值的货币,每种面值的货币可以使用任意张,再给定一个整数aim,代表要找的钱数,求换钱的方法数有多少种。由于方法的种数比较大,所以要求输出对109+710^9+7109+7进行取模后的答案。输入描述:输出包括两行,第一行包括两个整数n(0≤n≤1000)(0\leqn\leq1000)(0≤n≤1000)和a
- 程序员代码面试指南刷题--第三章.打印二叉树的边界节点
一年而已
程序员代码面试指南刷题
题目描述给定一颗二叉树的根节点root,按照如下两种标准分别实现二叉树的边界节点的逆时针打印。标准一:1,根节点为边界节点。2,叶节点为边界节点。3,如果节点在其所在的层中是最左的或最右的,那么该节点也是边界节点。标准二:1,根节点为边界节点。2,叶节点为边界节点。3,树左边界延伸下去的路径为边界节点。4,树右边界延伸下去的路径为边界节点。ps:具体请对照样例输入描述:第一行输入两个整数n和roo
- 程序员代码面试指南刷题--第二章.在链表中删除指定值的节点
一年而已
程序员代码面试指南刷题
题目描述给出一个链表和一个整数num,输出删除链表中节点值等于num的节点之后的链表。输入描述:第一行一个整数n,n表示单链表的节点数量。第二行n个整数表示单链表的各个节点的值。第三行一个整数num。输出描述:在给定的函数中返回指定链表的头指针。示例1输入412343输出124解法一:添加一个头结点便于操作importjava.io.*;publicclassMain{publicstaticBu
- 程序员代码面试指南刷题--第九章.一行代码求两个数的最大公约数
一年而已
程序员代码面试指南刷题
题目描述给定两个不等于0的整数M和N,求M和N的最大公约数。输入描述:输入有两个整数。分别表示M,N输出描述:一个整数表示M,N的最大公约数示例1输入612输出6解法一:辗转相除法importjava.io.*;publicclassMain{publicstaticvoidmain(String[]args)throwsIOException{BufferedReaderbr=newBuffer
- 程序员代码面试指南刷题--第四章.打气球的最大分数
一年而已
程序员代码面试指南刷题
题目描述给定一个数组arr,长度为n。代表排有分数的气球。每打爆一个气球都能获得分数,假设打爆气球的分数为X,获得分数的规则如下:1)如果被打爆气球的左边有没被打爆的气球,找到离被打爆气球最近的气球,假设分数为L:如果被打爆气球的右边有没被打爆的气球,找到离被打爆气球最近的气球,假设分数为R.获得分数为LXR2)如果被打爆的气球的左边有没被打爆的气球,找到离被打爆气球最近的气球,假设分数为L:如果
- 程序员代码面试指南刷题--第五章.翻转字符串(2)
一年而已
程序员代码面试指南刷题
题目描述给一个字符类型的数组chas和一个整数size,请把大小为size的左半区整体右移到右半区,右半区整体移动到左边。输入描述:输入两行,第一行一个整数,代表size,第二行一个字符串,代表chas输出描述:输出一行字符串,代表翻转后的字符串。示例1输入3abcdefg输出defgabc解法一:偷个懒importjava.io.*;importjava.util.*;publicclassMa
- 程序员代码面试指南刷题--第四章.数组中的最长连续子序列
一年而已
程序员代码面试指南刷题
题目描述给定无序数组arr,返回其中最长的连续序列的长度(要求值连续,位置可以不连续,例如3,4,5,6为连续的自然数)输入描述:输出两行,第一行包括一个整数n,第二行包含n个整数,分别代表arr[i]输出描述:输出一个整数,代表最长连续子序列的长度。示例1输入61004200132输出4示例2输入3111输出1解法一:动态规划importjava.io.*;importjava.util.*;p
- 程序员代码面试指南刷题--第四章.最长公共子串
一年而已
程序员代码面试指南刷题
题目描述:给定两个字符串str1和str2,输出两个字符串的最长公共子串,如果最长公共子串为空,输出-1。输入描述:输入包括两行,第一行代表字符串srr1,第二行代表字符串str2。输出描述:输出包括一行,代表最长公共子串。示例1输入1AB2345CD12345EF输出2345解法一:动态规划思路:还是难在确定如何抽象importjava.io.*;importjava.util.*;public
- 程序员代码面试指南刷题--第四章.最长公共子序列
一年而已
程序员代码面试指南刷题
题目描述给定两个字符串str1和str2,输出连个字符串的最长公共子序列。如过最长公共子序列为空,则输出-1。输入描述:输出包括两行,第一行代表字符串str1,第二行代表str2。(1≤length(str1),length(str2)≤5000)\left(1\leqlength(str1),length(str2)\leq5000\right)(1≤length(str1),length(st
- 程序员代码面试指南刷题--第一章.用一个栈实现另一个栈的排序
一年而已
程序员代码面试指南刷题
题目描述一个栈中元素的类型为整型,现在想将该栈从顶到底按从大到小的顺序排序,只许申请一个栈。除此之外,可以申请新的变量,但不能申请额外的数据结构。如何完成排序?输入描述:第一行输入一个N,表示栈中元素的个数第二行输入N个整数aia_iai表示栈顶到栈底的各个元素输出描述:输出一行表示排序后的栈中栈顶到栈底的各个元素。示例1输入558436输出86543解法一:oj有点难过importjava.io
- 程序员代码面试指南刷题--第四章.最长递增子序列
一年而已
程序员代码面试指南刷题
题目描述给定数组arr,设长度为n,输出arr的最长递增子序列。(如果有多个答案,请输出其中字典序最小的)输入描述:输出两行,第一行包括一个正整数n(ndp[max]){//找到第一个maxmax=i;}}int[]res=null;for(inti=max;itmp[j]){res=tmp;}}}}}returnres;}publicstaticint[]getOneRes(int[]arr,i
- 程序员代码面试指南刷题--第四章.机器人达到指定位置方法数
一年而已
程序员代码面试指南刷题
题目描述假设有排成一行的N个位置,记为1~N,开始时机器人在M位置,机器人可以往左或者往右走,如果机器人在1位置,那么下一步机器人只能走到2位置,如果机器人在N位置,那么下一步机器人只能走到N-1位置。规定机器人只能走k步,最终能来到P位置的方法有多少种。由于方案数可能比较大,所以答案需要对1e9+7取模。输入描述:输出包括一行四个正整数N(2n||pn)return0;returnwalk(n,
- 程序员代码面试指南刷题--第二章.合并两个有序的单链表
一年而已
程序员代码面试指南刷题
题目描述给定两个升序的单链表的头节点head1和head2,请合并两个升序链表,合并后的链表依然升序,并返回合并后链表的头节点。输入描述:两个升序的单链表的头节点head1和head2输出描述:在给定的函数内返回新链表的头指针。示例1输入5123456789101112输出12345789101112备注:保证链表的长度不大于1000000解法一:按题意importjava.io.Buffered
- 程序员代码面试指南刷题--第八章.数组中子数组的最大累乘积
一年而已
程序员代码面试指南刷题
题目描述给定一个double类型的数组arr,其中的元素可正、可负、可0,返回子数组累乘的最大乘积。例如,arr=[-2.5,4,0,3,0.5,8,-1],子数组[3,0.5,8]累乘可以获得最大的乘积12,所以返回12[要求]时间复杂度为O(n)O(n)O(n),空间复杂度为O(1)O(1)O(1)输入描述:第一行一个整数N。表示数组长度。接下来一行N个浮点数表示数组内的数输出描述:输出一个浮
- 程序员代码面试指南刷题--第五章.将整数字符串转成整数值
一年而已
程序员代码面试指南刷题
题目描述给定一个字符串str,如果str符合日常书写的整数形式,并且属于32位整数范围,返回str代表的整数值,否则返回0。输入描述:输出包括一行代表str(1≤length(str)≤100)(1\leqlength(str)\leq100)(1≤length(str)≤100)。输出描述:输出一行,代表返回的值。示例1输入123输出123示例2输入023输出0示例3输入A13输出0示例4输入2
- 程序员代码面试指南刷题--第四章.数字字符转化为字母组合的种数
一年而已
程序员代码面试指南刷题
题目描述给定一个字符串str,str全部由数字字符组成,如果str中的某一个或者相邻两个字符组成的子串值在1~26之间,则这个子串可以转换为一个字母。规定‘1’转换为“A”,“2”转换为“B”…"26"转化为“Z“。请求出str有多少种不同的转换结果,由于答案可能会比较大,所以请输出对10^9+7取模后的答案。输入描述:输出一行仅有’0‘~’9‘组成的字符串,代表str(0≤length(str)
- 程序员代码面试指南刷题--第二章.反转单向链表
一年而已
程序员代码面试指南刷题
题目描述实现反转单向链表和双向链表的函数。如1->2->3反转后变成3->2->1。输入描述:第一行一个整数n,表示单链表的长度。第二行n个整数val表示单链表的各个节点。第三行一个整数m,表示双链表的长度。第四行m个整数val表示双链表的各个节点。输出描述:在给定的函数内返回相应链表的头指针。示例1输入312341234输出3214321解法一:不难但是一次就能跑出来还是很有成就感的import
- 程序员代码面试指南刷题--第八章.在数组中找到出现次数大于一半的数
一年而已
程序员代码面试指南刷题
题目描述给定一个整型数组arr,请打印其中出现次数大于一半的数,如果没有这样的数,请输出-1。输入描述:输入包含两行,第一行包含一个整数n,代表数组长度,第二行包含n个数,代表数组arr。输出描述:输出一个整数,代表出现次数大于一半的数,如果没有这样的数,请输出‘-1“。示例1输入5117577输出7解法一:两两相消importjava.io.*;importjava.util.*;publicc
- 程序员代码面试指南刷题--第八章.在数组中找到出现次数大于n/k的数
一年而已
程序员代码面试指南刷题
题目描述给定一个整型数组arr,再给定一个整数k,打印所有出现次数大于n/k的数,如果没有这样的数,请打印”-1“。输入描述:输入包含两行,第一行输入包含两个整数n和k,第二行包含n个整数,代表数组arr。输出描述:输出所有出现次数大于n/k的数,如果没有这样的数,请输出”-1“。示例1输入771231234输出123解法一:利用mapimportjava.io.*;importjava.util
- 程序员代码面试指南刷题--第二章.将单向链表按某值划分为左边小,中间相等,右边大的形式
一年而已
程序员代码面试指南刷题
题目描述给定一个链表,再给定一个整数pivot,请将链表调整为左部分都是值小于pivot的节点,中间部分都是值等于pivot的节点,右边部分都是大于pivot的节点。除此之外,对调整后的节点顺序没有更多要求。输入描述:第一行两个整数n和pivot,n表示链表的长度。第二行n个整数ai表示链表的节点。输出描述:请在给定的函数内返回链表的头指针。示例1输入5390451输出10459备注:1≤n≤10
- 程序员代码面试指南刷题--第五章.找到字符串的最长无重复字符子串
一年而已
程序员代码面试指南刷题
题目描述给定一个数组arr,返回arr的最长无的重复子串的长度(无重复指的是所有字母都不相同)。输入描述:输入包含两行,第一行包含一个整数n(1≤n≤10^5),代表数组arr的长度,第二行包含n个整数,代表数组arr(1≤arr[i]≤10^6)。输出描述:输出一个整数,代表arr的最长无重复字符的长度。示例1输入42345输出4示例2输入522343输出3解法一:借助hash表importja
- 程序员代码面试指南刷题--第二章.判断一个链表是否为回文结构
一年而已
程序员代码面试指南刷题
题目描述给定一个链表,请判断该链表是否为回文结构。输入描述:n表示链表的长度ai表示链表的各个节点的值。输出描述:如果为回文结构输出“true”,否则输出“false”。示例1输入41221输出true备注:1≤n≤1000000−1000000≤ai≤1000000解法一:利用栈importjava.io.*;importjava.util.*;publicclassMain{publicst
- jQuery 跨域访问的三种方式 No 'Access-Control-Allow-Origin' header is present on the reque
qiaolevip
每天进步一点点学习永无止境跨域众观千象
XMLHttpRequest cannot load http://v.xxx.com. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:63342' is therefore not allowed access. test.html:1
- mysql 分区查询优化
annan211
java分区优化mysql
分区查询优化
引入分区可以给查询带来一定的优势,但同时也会引入一些bug.
分区最大的优点就是优化器可以根据分区函数来过滤掉一些分区,通过分区过滤可以让查询扫描更少的数据。
所以,对于访问分区表来说,很重要的一点是要在where 条件中带入分区,让优化器过滤掉无需访问的分区。
可以通过查看explain执行计划,是否携带 partitions
- MYSQL存储过程中使用游标
chicony
Mysql存储过程
DELIMITER $$
DROP PROCEDURE IF EXISTS getUserInfo $$
CREATE PROCEDURE getUserInfo(in date_day datetime)-- -- 实例-- 存储过程名为:getUserInfo-- 参数为:date_day日期格式:2008-03-08-- BEGINdecla
- mysql 和 sqlite 区别
Array_06
sqlite
转载:
http://www.cnblogs.com/ygm900/p/3460663.html
mysql 和 sqlite 区别
SQLITE是单机数据库。功能简约,小型化,追求最大磁盘效率
MYSQL是完善的服务器数据库。功能全面,综合化,追求最大并发效率
MYSQL、Sybase、Oracle等这些都是试用于服务器数据量大功能多需要安装,例如网站访问量比较大的。而sq
- pinyin4j使用
oloz
pinyin4j
首先需要pinyin4j的jar包支持;jar包已上传至附件内
方法一:把汉字转换为拼音;例如:编程转换后则为biancheng
/**
* 将汉字转换为全拼
* @param src 你的需要转换的汉字
* @param isUPPERCASE 是否转换为大写的拼音; true:转换为大写;fal
- 微博发送私信
随意而生
微博
在前面文章中说了如和获取登陆时候所需要的cookie,现在只要拿到最后登陆所需要的cookie,然后抓包分析一下微博私信发送界面
http://weibo.com/message/history?uid=****&name=****
可以发现其发送提交的Post请求和其中的数据,
让后用程序模拟发送POST请求中的数据,带着cookie发送到私信的接入口,就可以实现发私信的功能了。
- jsp
香水浓
jsp
JSP初始化
容器载入JSP文件后,它会在为请求提供任何服务前调用jspInit()方法。如果您需要执行自定义的JSP初始化任务,复写jspInit()方法就行了
JSP执行
这一阶段描述了JSP生命周期中一切与请求相关的交互行为,直到被销毁。
当JSP网页完成初始化后
- 在 Windows 上安装 SVN Subversion 服务端
AdyZhang
SVN
在 Windows 上安装 SVN Subversion 服务端2009-09-16高宏伟哈尔滨市道里区通达街291号
最佳阅读效果请访问原地址:http://blog.donews.com/dukejoe/archive/2009/09/16/1560917.aspx
现在的Subversion已经足够稳定,而且已经进入了它的黄金时段。我们看到大量的项目都在使
- android开发中如何使用 alertDialog从listView中删除数据?
aijuans
android
我现在使用listView展示了很多的配置信息,我现在想在点击其中一条的时候填出 alertDialog,点击确认后就删除该条数据,( ArrayAdapter ,ArrayList,listView 全部删除),我知道在 下面的onItemLongClick 方法中 参数 arg2 是选中的序号,但是我不知道如何继续处理下去 1 2 3
- jdk-6u26-linux-x64.bin 安装
baalwolf
linux
1.上传安装文件(jdk-6u26-linux-x64.bin)
2.修改权限
[root@localhost ~]# ls -l /usr/local/jdk-6u26-linux-x64.bin
3.执行安装文件
[root@localhost ~]# cd /usr/local
[root@localhost local]# ./jdk-6u26-linux-x64.bin&nbs
- MongoDB经典面试题集锦
BigBird2012
mongodb
1.什么是NoSQL数据库?NoSQL和RDBMS有什么区别?在哪些情况下使用和不使用NoSQL数据库?
NoSQL是非关系型数据库,NoSQL = Not Only SQL。
关系型数据库采用的结构化的数据,NoSQL采用的是键值对的方式存储数据。
在处理非结构化/半结构化的大数据时;在水平方向上进行扩展时;随时应对动态增加的数据项时可以优先考虑使用NoSQL数据库。
在考虑数据库的成熟
- JavaScript异步编程Promise模式的6个特性
bijian1013
JavaScriptPromise
Promise是一个非常有价值的构造器,能够帮助你避免使用镶套匿名方法,而使用更具有可读性的方式组装异步代码。这里我们将介绍6个最简单的特性。
在我们开始正式介绍之前,我们想看看Javascript Promise的样子:
var p = new Promise(function(r
- [Zookeeper学习笔记之八]Zookeeper源代码分析之Zookeeper.ZKWatchManager
bit1129
zookeeper
ClientWatchManager接口
//接口的唯一方法materialize用于确定那些Watcher需要被通知
//确定Watcher需要三方面的因素1.事件状态 2.事件类型 3.znode的path
public interface ClientWatchManager {
/**
* Return a set of watchers that should
- 【Scala十五】Scala核心九:隐式转换之二
bit1129
scala
隐式转换存在的必要性,
在Java Swing中,按钮点击事件的处理,转换为Scala的的写法如下:
val button = new JButton
button.addActionListener(
new ActionListener {
def actionPerformed(event: ActionEvent) {
- Android JSON数据的解析与封装小Demo
ronin47
转自:http://www.open-open.com/lib/view/open1420529336406.html
package com.example.jsondemo;
import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;
impor
- [设计]字体创意设计方法谈
brotherlamp
UIui自学ui视频ui教程ui资料
从古至今,文字在我们的生活中是必不可少的事物,我们不能想象没有文字的世界将会是怎样。在平面设计中,UI设计师在文字上所花的心思和功夫最多,因为文字能直观地表达UI设计师所的意念。在文字上的创造设计,直接反映出平面作品的主题。
如设计一幅戴尔笔记本电脑的广告海报,假设海报上没有出现“戴尔”两个文字,即使放上所有戴尔笔记本电脑的图片都不能让人们得知这些电脑是什么品牌。只要写上“戴尔笔
- 单调队列-用一个长度为k的窗在整数数列上移动,求窗里面所包含的数的最大值
bylijinnan
java算法面试题
import java.util.LinkedList;
/*
单调队列 滑动窗口
单调队列是这样的一个队列:队列里面的元素是有序的,是递增或者递减
题目:给定一个长度为N的整数数列a(i),i=0,1,...,N-1和窗长度k.
要求:f(i) = max{a(i-k+1),a(i-k+2),..., a(i)},i = 0,1,...,N-1
问题的另一种描述就
- struts2处理一个form多个submit
chiangfai
struts2
web应用中,为完成不同工作,一个jsp的form标签可能有多个submit。如下代码:
<s:form action="submit" method="post" namespace="/my">
<s:textfield name="msg" label="叙述:">
- shell查找上个月,陷阱及野路子
chenchao051
shell
date -d "-1 month" +%F
以上这段代码,假如在2012/10/31执行,结果并不会出现你预计的9月份,而是会出现八月份,原因是10月份有31天,9月份30天,所以-1 month在10月份看来要减去31天,所以直接到了8月31日这天,这不靠谱。
野路子解决:假设当天日期大于15号
- mysql导出数据中文乱码问题
daizj
mysql中文乱码导数据
解决mysql导入导出数据乱码问题方法:
1、进入mysql,通过如下命令查看数据库编码方式:
mysql> show variables like 'character_set_%';
+--------------------------+----------------------------------------+
| Variable_name&nbs
- SAE部署Smarty出现:Uncaught exception 'SmartyException' with message 'unable to write
dcj3sjt126com
PHPsmartysae
对于SAE出现的问题:Uncaught exception 'SmartyException' with message 'unable to write file...。
官方给出了详细的FAQ:http://sae.sina.com.cn/?m=faqs&catId=11#show_213
解决方案为:
01
$path
- 《教父》系列台词
dcj3sjt126com
Your love is also your weak point.
你的所爱同时也是你的弱点。
If anything in this life is certain, if history has taught us anything, it is
that you can kill anyone.
不顾家的人永远不可能成为一个真正的男人。 &
- mongodb安装与使用
dyy_gusi
mongo
一.MongoDB安装和启动,widndows和linux基本相同
1.下载数据库,
linux:mongodb-linux-x86_64-ubuntu1404-3.0.3.tgz
2.解压文件,并且放置到合适的位置
tar -vxf mongodb-linux-x86_64-ubun
- Git排除目录
geeksun
git
在Git的版本控制中,可能有些文件是不需要加入控制的,那我们在提交代码时就需要忽略这些文件,下面讲讲应该怎么给Git配置一些忽略规则。
有三种方法可以忽略掉这些文件,这三种方法都能达到目的,只不过适用情景不一样。
1. 针对单一工程排除文件
这种方式会让这个工程的所有修改者在克隆代码的同时,也能克隆到过滤规则,而不用自己再写一份,这就能保证所有修改者应用的都是同一
- Ubuntu 创建开机自启动脚本的方法
hongtoushizi
ubuntu
转载自: http://rongjih.blog.163.com/blog/static/33574461201111504843245/
Ubuntu 创建开机自启动脚本的步骤如下:
1) 将你的启动脚本复制到 /etc/init.d目录下 以下假设你的脚本文件名为 test。
2) 设置脚本文件的权限 $ sudo chmod 755
- 第八章 流量复制/AB测试/协程
jinnianshilongnian
nginxluacoroutine
流量复制
在实际开发中经常涉及到项目的升级,而该升级不能简单的上线就完事了,需要验证该升级是否兼容老的上线,因此可能需要并行运行两个项目一段时间进行数据比对和校验,待没问题后再进行上线。这其实就需要进行流量复制,把流量复制到其他服务器上,一种方式是使用如tcpcopy引流;另外我们还可以使用nginx的HttpLuaModule模块中的ngx.location.capture_multi进行并发
- 电商系统商品表设计
lkl
DROP TABLE IF EXISTS `category`; -- 类目表
/*!40101 SET @saved_cs_client = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `category` (
`id` int(11) NOT NUL
- 修改phpMyAdmin导入SQL文件的大小限制
pda158
sqlmysql
用phpMyAdmin导入mysql数据库时,我的10M的
数据库不能导入,提示mysql数据库最大只能导入2M。
phpMyAdmin数据库导入出错: You probably tried to upload too large file. Please refer to documentation for ways to workaround this limit.
- Tomcat性能调优方案
Sobfist
apachejvmtomcat应用服务器
一、操作系统调优
对于操作系统优化来说,是尽可能的增大可使用的内存容量、提高CPU的频率,保证文件系统的读写速率等。经过压力测试验证,在并发连接很多的情况下,CPU的处理能力越强,系统运行速度越快。。
【适用场景】 任何项目。
二、Java虚拟机调优
应该选择SUN的JVM,在满足项目需要的前提下,尽量选用版本较高的JVM,一般来说高版本产品在速度和效率上比低版本会有改进。
J
- SQLServer学习笔记
vipbooks
数据结构xml
1、create database school 创建数据库school
2、drop database school 删除数据库school
3、use school 连接到school数据库,使其成为当前数据库
4、create table class(classID int primary key identity not null)
创建一个名为class的表,其有一