键盘常用符号英文:
~ tilde / swung dash
! exclamation mark
? question mark
@ at sign
# crosshatch / sharp / hash
$ dollar sign
% percent sign
^ caret
& ampersand
* asterisk / star
() parentheses / round brackets
[] brackets / square brackets
{} braces / curly brackets
<> chevrons / angle brackets
_ underscore
- hyphen / dash / minus sign
" quotation mark / double quote
' apostrophe / single quote
` grave accent / backquote
. period / dot / point
, comma
: colon
; semicolon
... ellipsis
| bar / pipe / vertical bar
/ slash / forward slash
\ backslash
Sunday, December 31, 2017
Sunday, December 17, 2017
shell script
数值运算: $((计算式)), total = $((${var1}*${var2}))
/path/to/scriptname opt1 opt2 opt3 opt4
$0 $1 $2 $3 $4
$# :代表后接的参数“个数”,以上表为例这里显示为“ 4 ”;
$@ :代表“ "$1" "$2" "$3" "$4" ”之意,每个变量是独立的(用双引号括起来);
$* :代表“ "$1c$2c$3c$4" ”,其中 c 为分隔字符,默 认为空白键, 所以本例中代表“ "$1 $2 $3 $4" ”之意。
关于某个文件名的“文件类 型”判断
test -e filename 该“文件名”是否存在
-f 该“文件名”是否存在且为文件
-d 该“文件名”是否存在且为目录
-L 该“文件名”是否存在且为一个链接文件
关于文件的权限侦测
test -r filename 该“文件名”是否存在且具有“可读”的权限
-w 该“文件名”是否存在且具有“可写”的权限
-x 该“文件名”是否存在且具有“可执行”的权限
-u 该“文件名”是否存在且具有“SUID”的属性
-g 该“文件名”是否存在且具有“SGID”的属性
-k 该“文件名”是否存在且具有“Sticky bit”的属性
-s 该“文件名”是否存在且为“非空白文件”
两个文件之间的比较
test file1 -nt file2 判断 file1 是否比 file2 新
-ot 判断 file1 是否比 file2 旧
-ef 判断 file1 与 file2 是否为同一文件,可用在判断 hard link 的判定上
关于两个整数之间的判定
test n1 -eq n2 两数值相等 (equal)
-ne 两数值不等 (not equal)
-gt n1 大于 n2 (greater than)
-lt n1 小于 n2 (less than)
-ge n1 大于等于 n2 (greater than or equal)
-le n1 小于等于 n2 (less than or equal)
判定字串的数据
test -z string 判定字串是否为 0? 若 string 为空字串,则为 true
test -n string 判定字串是否为非0? 若 string 为空字串,则为 false, -n 亦可省略
test str1 == str2 判定 str1 是否等于 str2 ,若相等,则回传 true
test str1 != str2 判定 str1 是否不等于 str2 ,若相等,则回传 false
多重条件判定
test -r filename -a -x filename 两条件同时成立, 才回传 true
test -r filename -o -x filename 两条件任何一个成立,就可回传 true
test ! -x file 当 file 不具有 x 时,回传 true
判断符号 [ ],功能类似test
在中括号内的每个元件都需要有空白键来分隔;
在中括号内的变量,最好都以双引号括号起来;
在中括号内的常数,最好都以单或双引号括号起来。
[ -z "${HOME}" ] 判断${HOME} 这个变量是否为空
条件判断式
if [ 条件判断式一 ]; then
当条件判断式一成立时,可以进行的指令工作内容;
elif [ 条件判断式二 ]; then
当条件判断式二成立时,可以进行的指令工作内容;
else
当条件判断式一与二均不成立时,可以进行的指令工作内容;
fi
case ..... esac 判断
case $变量名称 in
"第一个变量内容")
程序段
;;
"第二个变量内容")
程序段
;;
*)
不包含第一个变量内容与第二个变量内容的其他程序执行段
exit 1
;;
esac
while do done, until do done (不定循环)
当 condition 条件成立时,就进行循环,直 到 condition 的条件不成立才停止
while [ condition ]
do <==do 是循环的开始!
程序段落
done <==done 是循环的结束
当 condition 条件成立时,就终止循环, 否则就持续进行循环的程序段
until [ condition ]
do
程序段落
done
for...do...done (固定循环)
for var in con1 con2 con3 ...
do
程序段
done
for...do...done 的数值处理
for (( 初始值; 限制值; 执行步阶 ))
do
程序段
done
/path/to/scriptname opt1 opt2 opt3 opt4
$0 $1 $2 $3 $4
$# :代表后接的参数“个数”,以上表为例这里显示为“ 4 ”;
$@ :代表“ "$1" "$2" "$3" "$4" ”之意,每个变量是独立的(用双引号括起来);
$* :代表“ "$1c$2c$3c$4" ”,其中 c 为分隔字符,默 认为空白键, 所以本例中代表“ "$1 $2 $3 $4" ”之意。
关于某个文件名的“文件类 型”判断
test -e filename 该“文件名”是否存在
-f 该“文件名”是否存在且为文件
-d 该“文件名”是否存在且为目录
-L 该“文件名”是否存在且为一个链接文件
关于文件的权限侦测
test -r filename 该“文件名”是否存在且具有“可读”的权限
-w 该“文件名”是否存在且具有“可写”的权限
-x 该“文件名”是否存在且具有“可执行”的权限
-u 该“文件名”是否存在且具有“SUID”的属性
-g 该“文件名”是否存在且具有“SGID”的属性
-k 该“文件名”是否存在且具有“Sticky bit”的属性
-s 该“文件名”是否存在且为“非空白文件”
两个文件之间的比较
test file1 -nt file2 判断 file1 是否比 file2 新
-ot 判断 file1 是否比 file2 旧
-ef 判断 file1 与 file2 是否为同一文件,可用在判断 hard link 的判定上
关于两个整数之间的判定
test n1 -eq n2 两数值相等 (equal)
-ne 两数值不等 (not equal)
-gt n1 大于 n2 (greater than)
-lt n1 小于 n2 (less than)
-ge n1 大于等于 n2 (greater than or equal)
-le n1 小于等于 n2 (less than or equal)
判定字串的数据
test -z string 判定字串是否为 0? 若 string 为空字串,则为 true
test -n string 判定字串是否为非0? 若 string 为空字串,则为 false, -n 亦可省略
test str1 == str2 判定 str1 是否等于 str2 ,若相等,则回传 true
test str1 != str2 判定 str1 是否不等于 str2 ,若相等,则回传 false
多重条件判定
test -r filename -a -x filename 两条件同时成立, 才回传 true
test -r filename -o -x filename 两条件任何一个成立,就可回传 true
test ! -x file 当 file 不具有 x 时,回传 true
判断符号 [ ],功能类似test
在中括号内的每个元件都需要有空白键来分隔;
在中括号内的变量,最好都以双引号括号起来;
在中括号内的常数,最好都以单或双引号括号起来。
[ -z "${HOME}" ] 判断${HOME} 这个变量是否为空
条件判断式
if [ 条件判断式一 ]; then
当条件判断式一成立时,可以进行的指令工作内容;
elif [ 条件判断式二 ]; then
当条件判断式二成立时,可以进行的指令工作内容;
else
当条件判断式一与二均不成立时,可以进行的指令工作内容;
fi
case ..... esac 判断
case $变量名称 in
"第一个变量内容")
程序段
;;
"第二个变量内容")
程序段
;;
*)
不包含第一个变量内容与第二个变量内容的其他程序执行段
exit 1
;;
esac
while do done, until do done (不定循环)
当 condition 条件成立时,就进行循环,直 到 condition 的条件不成立才停止
while [ condition ]
do <==do 是循环的开始!
程序段落
done <==done 是循环的结束
当 condition 条件成立时,就终止循环, 否则就持续进行循环的程序段
until [ condition ]
do
程序段落
done
for...do...done (固定循环)
for var in con1 con2 con3 ...
do
程序段
done
for...do...done 的数值处理
for (( 初始值; 限制值; 执行步阶 ))
do
程序段
done
Tuesday, November 28, 2017
Iterm2+zsh+oh my zsh+Solarized+auto completion
zsh+on my zsh+iterm2
http://wdxtub.com/2016/02/18/oh-my-zsh/
http://wdxtub.com/2016/02/18/oh-my-zsh/
git clone https://github.com/bhilburn/powerlevel9k.git ~/.oh-my-zsh/custom/themes/powerlevel9k
OSX插件:
pfd:显示finder当前路径
cdf:进入finder当前路径
Auto-completion 1
http://yijiebuyi.com/blog/36955b84c57e338dd8255070b80829bf.html
Auto-completion 2
https://github.com/zsh-users/zsh-autosuggestions
Solarized 配色
http://www.jianshu.com/p/e45160d0ae27
ls 高亮
https://github.com/gibbling/dircolors
vim插件管理
http://blog.csdn.net/zhangpower1993/article/details/52184581
nerd 插件
http://www.jianshu.com/p/eXMxGx
.vimrc配置
set nocompatible " be iMproved, required
filetype off " required
" set the runtime path to include Vundle and initialize
set rtp+=~/.vim/bundle/Vundle.vim
call vundle#begin()
" let Vundle manage Bundles, required
Plugin 'VundleVim/Vundle.vim'
" plugin on GitHub repo, but not vim-scripts' repo
Plugin 'tpope/vim-fugitive'
Plugin 'Lokaltog/vim-powerline'
Plugin 'Valloric/YouCompleteMe'
Plugin 'scrooloose/nerdtree'
Plugin 'scrooloose/nerdcommenter'
Plugin 'kien/ctrlp.vim'
Plugin 'jelera/vim-javascript-syntax'
Plugin 'othree/html5.vim'
Plugin 'klen/python-mode'
Plugin 'vim-ruby/vim-ruby'
Plugin 'tpope/vim-rails'
Plugin 'jiangmiao/auto-pairs'
" plugin from http://vim-scripts.org/vim/scripts.html
" Git plugin not hosted on GitHub
"Plugin 'git://git.wincent.com/command-t.git'
" git repos on your local machine (i.e. when working on your own plugin)
"Plugin 'file:///home/gmarik/path/to/plugin'
" The sparkup vim script is in a subdirectory of this repo called vim.
" Pass the path to set the runtimepath properly.
"Plugin 'rstacruz/sparkup', {'rtp': 'vim/'}
" Install L9 and avoid a Naming conflict if you've already installed a
" different version somewhere else.
" All of your Plugins must be added before the following line
call vundle#end() " required
filetype plugin indent on " required
" To ignore plugin indent changes, instead use:
"filetype plugin on
"
" Brief help
" :PluginList - lists configured plugins
" :PluginInstall - installs plugins; append `!` to update or just :PluginUpdate
" :PluginSearch foo - searches for foo; append `!` to refresh local cache
" :PluginClean - confirms removal of unused plugins; append `!` to auto-approve removal
"
" see :h vundle for more details or wiki for FAQ
" Put your non-Plugin stuff after this line
let mapleader=','
set clipboard=unnamed
set mouse=a "启用鼠标
set nobackup
set nowritebackup
set noswapfile
set hlsearch "高亮搜索结果
set incsearch "搜索时一边输入一边显示效果
set tabstop=4
set shiftwidth=4
set t_Co=256
set backspace=2 "可随时用倒退键删除
set autoindent "自动缩进
set cindent "针对C语言的自动缩进
set smartindent "智能缩进
set ruler "可显示最后一列的状态
set cursorline "突出显示当前行
set showmatch "插入括号时,短暂地跳转到匹配的对应括号
set showmode "左下角那一列的状态
set showcmd "display incomplete commands
set nowrapscan "禁止在搜索到文件两端时重新搜索
set ic "搜索时忽略大小写
set foldenable "开始折叠
set foldmethod=syntax "设置语法折叠
set foldcolumn=0 "设置折叠区域的宽度
setlocal foldlevel=1 "设置折叠层数为
nnoremap <space> @=((foldclosed(line('.')) < 0) ? 'zc' : 'zo')<CR> " 用空格键来开关折叠
set laststatus=2 "显示状态栏 (默认值为 1, 无法显示状态栏)
set nu "可以在每一列的最前面显示行号
set bg=dark "显示不同的底色色调
syntax on "进行语法检验,颜色显示
syntax enable
colorscheme solarized
" Nerd Tree
let NERDChristmasTree=0
let NERDTreeWinSize=40
let NERDTreeChDirMode=2
let NERDTreeIgnore=['\~$', '\.pyc$', '\.swp$']
let NERDTreeShowBookmarks=1
let NERDTreeWinPos="left"
autocmd vimenter * if !argc() | NERDTree | endif " Automatically open a NERDTree if no files where specified
autocmd bufenter * if (winnr("$") == 1 && exists("b:NERDTreeType") && b:NERDTreeType == "primary") | q | endif " Close vim if the only window left open is a NERDTree
nmap <F5> :NERDTreeToggle<cr>
" Add spaces after comment delimiters by default
let g:NERDSpaceDelims = 1
" Use compact syntax for prettified multi-line comments
let g:NERDCompactSexyComs = 1
" Align line-wise comment delimiters flush left instead of following code indentation
let g:NERDDefaultAlign = 'left'
" Set a language to use its alternate delimiters by default
let g:NERDAltDelims_java = 1
" Allow commenting and inverting empty lines (useful when commenting a region)
let g:NERDCommentEmptyLines = 1
" Enable trimming of trailing whitespace when uncommenting
let g:NERDTrimTrailingWhitespace = 1
# ZSH的环境变量
export ZSH=/Users/songjiang/.oh-my-zsh
# 主题设置
# 主题列表在 ~/.oh-my-zsh/themes/
# 如果设置为 "random", 每次开启都会是不同的主题
ZSH_THEME="agnoster"
# 如果想要大小写敏感,可以取消注释下面的一行
# CASE_SENSITIVE="true"
# 如果想要连接符不敏感,可以取消注释下面的一行。_ 和 - 将可以互换
# HYPHEN_INSENSITIVE="true"
# 如果不想要自动更新,可以取消注释下面的一行
# DISABLE_AUTO_UPDATE="true"
# 自动更新的时间间隔,单位是天,这里设置 30 天更新一次
export UPDATE_ZSH_DAYS=60
# 如果不想要 ls 命令输出带颜色,可以取消注释下面的一行
# DISABLE_LS_COLORS="true"
# 是否禁止更改终端标题,不要禁止,不然所有终端tab只显示zsh了,而不随着目录的改变而改变显示
# DISABLE_AUTO_TITLE="true"
# 自动纠正命令,不启用,不怎么好用
# ENABLE_CORRECTION="true"
# 按tab键补全命令的时候,如果没什么可补全的就会出现三个红点,更人性化显示,这里我们启用
COMPLETION_WAITING_DOTS="true"
# Uncomment the following line if you want to disable marking untracked files
# under VCS as dirty. This makes repository status check for large repositories
# much, much faster.
# 不要在意这些细节,不需要改动
# DISABLE_UNTRACKED_FILES_DIRTY="true"
# 历史命令日期显示格式
# 有三种方式: "mm/dd/yyyy"|"dd.mm.yyyy"|"yyyy-mm-dd",我比较习惯最后那种
HIST_STAMPS="yyyy-mm-dd"
# Would you like to use another custom folder than $ZSH/custom?
# ZSH_CUSTOM=/path/to/new-custom-folder
# Which plugins would you like to load? (plugins can be found in ~/.oh-my-zsh/plugins/*)
# Custom plugins may be added to ~/.oh-my-zsh/custom/plugins/
# Example format: plugins=(rails git textmate ruby lighthouse)
# 插件设置,如果添加太多启动速度会比较慢
plugins=(git autojump osx)
[[ -s ~/.autojump/etc/profile.d/autojump.zsh ]] && . ~/.autojump/etc/profile.d/autojump.zsh
# 剩下部分比较不常改动
# User configuration
export PATH="/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/opt/X11/bin:/Library/TeX/texbin"
# export MANPATH="/usr/local/man:$MANPATH"
source $ZSH/oh-my-zsh.sh
# You may need to manually set your language environment
# export LANG=en_US.UTF-8
# Preferred editor for local and remote sessions
# if [[ -n $SSH_CONNECTION ]]; then
# export EDITOR='vim'
# else
# export EDITOR='mvim'
# fi
# Compilation flags
# export ARCHFLAGS="-arch x86_64"
# ssh
# export SSH_KEY_PATH="~/.ssh/dsa_id"
# Set personal aliases, overriding those provided by oh-my-zsh libs,
# plugins, and themes. Aliases can be placed here, though oh-my-zsh
# users are encouraged to define aliases within the ZSH_CUSTOM folder.
# For a full list of active aliases, run `alias`.
# Example aliases
# alias zshconfig="mate ~/.zshrc"
# alias ohmyzsh="mate ~/.oh-my-zsh"
alias ls='gls --color=auto'
alias ll='ls -al'
alias grep='grep --color'
alias egrep='egrep --color'
alias fgrep='fgrep --color'
#terminal变成256色
export TERM=xterm-256color
#语法高亮
source /usr/local/share/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh
#自动补全1(高级,但复制到terminal很慢)
#source ~/.oh-my-zsh/plugins/incr/incr*.zsh
#自动补全2(中级)
source /usr/local/share/zsh-autosuggestions/zsh-autosuggestions.zsh
#ls高亮
eval $(gdircolors ~/.dircolors/dircolors.256dark)
#export PYTHONPATH=/usr/local/lib/python3.6/site-packages:$PYTHONPATH
#
JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_65.jdk/Contents/Home
export JAVA_HOME
export PATH=$JAVA_HOME/bin:$PATH
OSX插件:
pfd:显示finder当前路径
cdf:进入finder当前路径
Auto-completion 1
http://yijiebuyi.com/blog/36955b84c57e338dd8255070b80829bf.html
Auto-completion 2
https://github.com/zsh-users/zsh-autosuggestions
Solarized 配色
http://www.jianshu.com/p/e45160d0ae27
ls 高亮
https://github.com/gibbling/dircolors
vim插件管理
http://blog.csdn.net/zhangpower1993/article/details/52184581
nerd 插件
http://www.jianshu.com/p/eXMxGx
.vimrc配置
set nocompatible " be iMproved, required
filetype off " required
" set the runtime path to include Vundle and initialize
set rtp+=~/.vim/bundle/Vundle.vim
call vundle#begin()
" let Vundle manage Bundles, required
Plugin 'VundleVim/Vundle.vim'
" plugin on GitHub repo, but not vim-scripts' repo
Plugin 'tpope/vim-fugitive'
Plugin 'Lokaltog/vim-powerline'
Plugin 'Valloric/YouCompleteMe'
Plugin 'scrooloose/nerdtree'
Plugin 'scrooloose/nerdcommenter'
Plugin 'kien/ctrlp.vim'
Plugin 'jelera/vim-javascript-syntax'
Plugin 'othree/html5.vim'
Plugin 'klen/python-mode'
Plugin 'vim-ruby/vim-ruby'
Plugin 'tpope/vim-rails'
Plugin 'jiangmiao/auto-pairs'
" plugin from http://vim-scripts.org/vim/scripts.html
" Git plugin not hosted on GitHub
"Plugin 'git://git.wincent.com/command-t.git'
" git repos on your local machine (i.e. when working on your own plugin)
"Plugin 'file:///home/gmarik/path/to/plugin'
" The sparkup vim script is in a subdirectory of this repo called vim.
" Pass the path to set the runtimepath properly.
"Plugin 'rstacruz/sparkup', {'rtp': 'vim/'}
" Install L9 and avoid a Naming conflict if you've already installed a
" different version somewhere else.
" All of your Plugins must be added before the following line
call vundle#end() " required
filetype plugin indent on " required
" To ignore plugin indent changes, instead use:
"filetype plugin on
"
" Brief help
" :PluginList - lists configured plugins
" :PluginInstall - installs plugins; append `!` to update or just :PluginUpdate
" :PluginSearch foo - searches for foo; append `!` to refresh local cache
" :PluginClean - confirms removal of unused plugins; append `!` to auto-approve removal
"
" see :h vundle for more details or wiki for FAQ
" Put your non-Plugin stuff after this line
let mapleader=','
set clipboard=unnamed
set mouse=a "启用鼠标
set nobackup
set nowritebackup
set noswapfile
set hlsearch "高亮搜索结果
set incsearch "搜索时一边输入一边显示效果
set tabstop=4
set shiftwidth=4
set t_Co=256
set backspace=2 "可随时用倒退键删除
set autoindent "自动缩进
set cindent "针对C语言的自动缩进
set smartindent "智能缩进
set ruler "可显示最后一列的状态
set cursorline "突出显示当前行
set showmatch "插入括号时,短暂地跳转到匹配的对应括号
set showmode "左下角那一列的状态
set showcmd "display incomplete commands
set nowrapscan "禁止在搜索到文件两端时重新搜索
set ic "搜索时忽略大小写
set foldenable "开始折叠
set foldmethod=syntax "设置语法折叠
set foldcolumn=0 "设置折叠区域的宽度
setlocal foldlevel=1 "设置折叠层数为
nnoremap <space> @=((foldclosed(line('.')) < 0) ? 'zc' : 'zo')<CR> " 用空格键来开关折叠
set laststatus=2 "显示状态栏 (默认值为 1, 无法显示状态栏)
set nu "可以在每一列的最前面显示行号
set bg=dark "显示不同的底色色调
syntax on "进行语法检验,颜色显示
syntax enable
colorscheme solarized
" Nerd Tree
let NERDChristmasTree=0
let NERDTreeWinSize=40
let NERDTreeChDirMode=2
let NERDTreeIgnore=['\~$', '\.pyc$', '\.swp$']
let NERDTreeShowBookmarks=1
let NERDTreeWinPos="left"
autocmd vimenter * if !argc() | NERDTree | endif " Automatically open a NERDTree if no files where specified
autocmd bufenter * if (winnr("$") == 1 && exists("b:NERDTreeType") && b:NERDTreeType == "primary") | q | endif " Close vim if the only window left open is a NERDTree
nmap <F5> :NERDTreeToggle<cr>
" Add spaces after comment delimiters by default
let g:NERDSpaceDelims = 1
" Use compact syntax for prettified multi-line comments
let g:NERDCompactSexyComs = 1
" Align line-wise comment delimiters flush left instead of following code indentation
let g:NERDDefaultAlign = 'left'
" Set a language to use its alternate delimiters by default
let g:NERDAltDelims_java = 1
" Allow commenting and inverting empty lines (useful when commenting a region)
let g:NERDCommentEmptyLines = 1
" Enable trimming of trailing whitespace when uncommenting
let g:NERDTrimTrailingWhitespace = 1
# ZSH的环境变量
export ZSH=/Users/songjiang/.oh-my-zsh
# 主题设置
# 主题列表在 ~/.oh-my-zsh/themes/
# 如果设置为 "random", 每次开启都会是不同的主题
ZSH_THEME="agnoster"
# 如果想要大小写敏感,可以取消注释下面的一行
# CASE_SENSITIVE="true"
# 如果想要连接符不敏感,可以取消注释下面的一行。_ 和 - 将可以互换
# HYPHEN_INSENSITIVE="true"
# 如果不想要自动更新,可以取消注释下面的一行
# DISABLE_AUTO_UPDATE="true"
# 自动更新的时间间隔,单位是天,这里设置 30 天更新一次
export UPDATE_ZSH_DAYS=60
# 如果不想要 ls 命令输出带颜色,可以取消注释下面的一行
# DISABLE_LS_COLORS="true"
# 是否禁止更改终端标题,不要禁止,不然所有终端tab只显示zsh了,而不随着目录的改变而改变显示
# DISABLE_AUTO_TITLE="true"
# 自动纠正命令,不启用,不怎么好用
# ENABLE_CORRECTION="true"
# 按tab键补全命令的时候,如果没什么可补全的就会出现三个红点,更人性化显示,这里我们启用
COMPLETION_WAITING_DOTS="true"
# Uncomment the following line if you want to disable marking untracked files
# under VCS as dirty. This makes repository status check for large repositories
# much, much faster.
# 不要在意这些细节,不需要改动
# DISABLE_UNTRACKED_FILES_DIRTY="true"
# 历史命令日期显示格式
# 有三种方式: "mm/dd/yyyy"|"dd.mm.yyyy"|"yyyy-mm-dd",我比较习惯最后那种
HIST_STAMPS="yyyy-mm-dd"
# Would you like to use another custom folder than $ZSH/custom?
# ZSH_CUSTOM=/path/to/new-custom-folder
# Which plugins would you like to load? (plugins can be found in ~/.oh-my-zsh/plugins/*)
# Custom plugins may be added to ~/.oh-my-zsh/custom/plugins/
# Example format: plugins=(rails git textmate ruby lighthouse)
# 插件设置,如果添加太多启动速度会比较慢
plugins=(git autojump osx)
[[ -s ~/.autojump/etc/profile.d/autojump.zsh ]] && . ~/.autojump/etc/profile.d/autojump.zsh
# 剩下部分比较不常改动
# User configuration
export PATH="/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/opt/X11/bin:/Library/TeX/texbin"
# export MANPATH="/usr/local/man:$MANPATH"
source $ZSH/oh-my-zsh.sh
# You may need to manually set your language environment
# export LANG=en_US.UTF-8
# Preferred editor for local and remote sessions
# if [[ -n $SSH_CONNECTION ]]; then
# export EDITOR='vim'
# else
# export EDITOR='mvim'
# fi
# Compilation flags
# export ARCHFLAGS="-arch x86_64"
# ssh
# export SSH_KEY_PATH="~/.ssh/dsa_id"
# Set personal aliases, overriding those provided by oh-my-zsh libs,
# plugins, and themes. Aliases can be placed here, though oh-my-zsh
# users are encouraged to define aliases within the ZSH_CUSTOM folder.
# For a full list of active aliases, run `alias`.
# Example aliases
# alias zshconfig="mate ~/.zshrc"
# alias ohmyzsh="mate ~/.oh-my-zsh"
alias ls='gls --color=auto'
alias ll='ls -al'
alias grep='grep --color'
alias egrep='egrep --color'
alias fgrep='fgrep --color'
#terminal变成256色
export TERM=xterm-256color
#语法高亮
source /usr/local/share/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh
#自动补全1(高级,但复制到terminal很慢)
#source ~/.oh-my-zsh/plugins/incr/incr*.zsh
#自动补全2(中级)
source /usr/local/share/zsh-autosuggestions/zsh-autosuggestions.zsh
#ls高亮
eval $(gdircolors ~/.dircolors/dircolors.256dark)
#export PYTHONPATH=/usr/local/lib/python3.6/site-packages:$PYTHONPATH
#
JAVA_HOME=/Library/Java/JavaVirtualMachines/jdk1.8.0_65.jdk/Contents/Home
export JAVA_HOME
export PATH=$JAVA_HOME/bin:$PATH
VIMRC:
Vimrc
source /apollo/env/envImprovement/var/vimrc
set nocompatible " be iMproved, required
filetype off " required
" set the runtime path to include Vundle and initialize
set rtp+=~/.vim/bundle/Vundle.vim
call vundle#begin()
" let Vundle manage Bundles, required
Plugin 'VundleVim/Vundle.vim'
" plugin on GitHub repo, but not vim-scripts' repo
Plugin 'tpope/vim-fugitive'
Plugin 'Lokaltog/vim-powerline'
Plugin 'Valloric/YouCompleteMe'
Plugin 'scrooloose/nerdtree'
Plugin 'scrooloose/nerdcommenter'
Plugin 'kien/ctrlp.vim'
Plugin 'jelera/vim-javascript-syntax'
Plugin 'othree/html5.vim'
Plugin 'klen/python-mode'
Plugin 'vim-ruby/vim-ruby'
Plugin 'tpope/vim-rails'
Plugin 'jiangmiao/auto-pairs'
" plugin from http://vim-scripts.org/vim/scripts.html
" Git plugin not hosted on GitHub
"Plugin 'git://git.wincent.com/command-t.git'
" git repos on your local machine (i.e. when working on your own plugin)
"Plugin 'file:///home/gmarik/path/to/plugin'
" The sparkup vim script is in a subdirectory of this repo called vim.
" Pass the path to set the runtimepath properly.
"Plugin 'rstacruz/sparkup', {'rtp': 'vim/'}
" Install L9 and avoid a Naming conflict if you've already installed a
" different version somewhere else.
" All of your Plugins must be added before the following line
call vundle#end() " required
filetype plugin indent on " required
" To ignore plugin indent changes, instead use:
"filetype plugin on
"
" Brief help
" :PluginList - lists configured plugins
" :PluginInstall - installs plugins; append `!` to update or just :PluginUpdate
" :PluginSearch foo - searches for foo; append `!` to refresh local cache
" :PluginClean - confirms removal of unused plugins; append `!` to auto-approve removal
"
" see :h vundle for more details or wiki for FAQ
" Put your non-Plugin stuff after this line
"
let mapleader=','
set clipboard=unnamed
set mouse=a "启用鼠标
set nobackup
set nowritebackup
set noswapfile
set hlsearch "高亮搜索结果
set incsearch "搜索时一边输入一边显示效果
set tabstop=4
set shiftwidth=4
set t_Co=256
set backspace=2 "可随时用倒退键删除
set autoindent "自动缩进
set cindent "针对C语言的自动缩进
set smartindent "智能缩进
set ruler "可显示最后一列的状态
set cursorline "突出显示当前行
set showmatch "插入括号时,短暂地跳转到匹配的对应括号
set showmode "左下角那一列的状态
set showcmd "display incomplete commands
set nowrapscan "禁止在搜索到文件两端时重新搜索
set ic "搜索时忽略大小写
set foldmethod=syntax "设置语法折叠
set foldcolumn=0 "设置折叠区域的宽度
setlocal foldlevel=1 "设置折叠层数为
nnoremap <space> @=((foldclosed(line('.')) < 0) ? 'zc' : 'zo')<CR> " 用空格键来开关折叠
set laststatus=2 "显示状态栏 (默认值为 1, 无法显示状态栏)
set nu "可以在每一列的最前面显示行号
set bg=dark "显示不同的底色色调
syntax on "进行语法检验,颜色显示
syntax enable
source /apollo/env/envImprovement/var/vimrc
set nocompatible " be iMproved, required
filetype off " required
" set the runtime path to include Vundle and initialize
set rtp+=~/.vim/bundle/Vundle.vim
call vundle#begin()
" let Vundle manage Bundles, required
Plugin 'VundleVim/Vundle.vim'
" plugin on GitHub repo, but not vim-scripts' repo
Plugin 'tpope/vim-fugitive'
Plugin 'Lokaltog/vim-powerline'
Plugin 'Valloric/YouCompleteMe'
Plugin 'scrooloose/nerdtree'
Plugin 'scrooloose/nerdcommenter'
Plugin 'kien/ctrlp.vim'
Plugin 'jelera/vim-javascript-syntax'
Plugin 'othree/html5.vim'
Plugin 'klen/python-mode'
Plugin 'vim-ruby/vim-ruby'
Plugin 'tpope/vim-rails'
Plugin 'jiangmiao/auto-pairs'
" plugin from http://vim-scripts.org/vim/scripts.html
" Git plugin not hosted on GitHub
"Plugin 'git://git.wincent.com/command-t.git'
" git repos on your local machine (i.e. when working on your own plugin)
"Plugin 'file:///home/gmarik/path/to/plugin'
" The sparkup vim script is in a subdirectory of this repo called vim.
" Pass the path to set the runtimepath properly.
"Plugin 'rstacruz/sparkup', {'rtp': 'vim/'}
" Install L9 and avoid a Naming conflict if you've already installed a
" different version somewhere else.
" All of your Plugins must be added before the following line
call vundle#end() " required
filetype plugin indent on " required
" To ignore plugin indent changes, instead use:
"filetype plugin on
"
" Brief help
" :PluginList - lists configured plugins
" :PluginInstall - installs plugins; append `!` to update or just :PluginUpdate
" :PluginSearch foo - searches for foo; append `!` to refresh local cache
" :PluginClean - confirms removal of unused plugins; append `!` to auto-approve removal
"
" see :h vundle for more details or wiki for FAQ
" Put your non-Plugin stuff after this line
"
let mapleader=','
set clipboard=unnamed
set mouse=a "启用鼠标
set nobackup
set nowritebackup
set noswapfile
set hlsearch "高亮搜索结果
set incsearch "搜索时一边输入一边显示效果
set tabstop=4
set shiftwidth=4
set t_Co=256
set backspace=2 "可随时用倒退键删除
set autoindent "自动缩进
set cindent "针对C语言的自动缩进
set smartindent "智能缩进
set ruler "可显示最后一列的状态
set cursorline "突出显示当前行
set showmatch "插入括号时,短暂地跳转到匹配的对应括号
set showmode "左下角那一列的状态
set showcmd "display incomplete commands
set nowrapscan "禁止在搜索到文件两端时重新搜索
set ic "搜索时忽略大小写
set foldmethod=syntax "设置语法折叠
set foldcolumn=0 "设置折叠区域的宽度
setlocal foldlevel=1 "设置折叠层数为
nnoremap <space> @=((foldclosed(line('.')) < 0) ? 'zc' : 'zo')<CR> " 用空格键来开关折叠
set laststatus=2 "显示状态栏 (默认值为 1, 无法显示状态栏)
set nu "可以在每一列的最前面显示行号
set bg=dark "显示不同的底色色调
syntax on "进行语法检验,颜色显示
syntax enable
ZSHRC:
Zshrc
export BRAZIL_WORKSPACE_DEFAULT_LAYOUT=short
for f in SDETools envImprovement AmazonAwsCli OdinTools; do
if [[ -d /apollo/env/$f ]]; then
export PATH=$PATH:/apollo/env/$f/bin
fi
done
export AUTO_TITLE_SCREENS="NO"
export PROMPT="
%{$fg[white]%}(%D %*) <%?> [%~] $program %{$fg[default]%}
%{$fg[cyan]%}%m %#%{$fg[default]%} "
export RPROMPT=
set-title() {
echo -e "\e]0;$*\007"
}
ssh() {
set-title $*;
/usr/bin/ssh -2 $*;
set-title $HOST;
}
alias timberIAD='sshenv TimberFS/IAD/DeeOpsTimber' #NA Gamma, NA Prod, EU Alpha, EU Beta
alias timberDUB='sshenv TimberFS/DUB/DeeOpsTimber' #EU Gamma, EU Prod
alias timberPDX='sshenv TimberFS/PDX/DeeOpsTimber' #FE Gamma, FE Prod, NA Alpha, NA Beta
if [ -f ~/.zshrc-dev-dsk-post ]; then
source ~/.zshrc-dev-dsk-post
fi
PATH="/usr/NX/bin:/usr/local/bin:/bin:/usr/bin:/home/sonjiang/bin:/usr/local/sbin:/usr/sbin:/sbin:/apollo/env/envImprovement/bin:/apollo/env/AmazonAwsCli/bin:/apollo/env/OdinTools/bin"
alias vim='/apollo/env/envImprovement/bin/vim'
alias ..="cd .."
alias ...="cd ../.."
alias ....="cd ../../.."
alias e=emacs
alias bb=brazil-build
alias bbs='bb server'
alias bws='brazil ws'
alias dryrun='brazil ws --dryrun'
alias e=emacs
alias bb=brazil-build
alias bbs='bb server'
alias bws='brazil ws'
alias dryrun='brazil ws --dryrun'
alias bshow='brazil ws show'
alias bsync='brazil ws sync -md'
alias bclean='bws clean'
alias brmws='brazil ws --delete --root'
alias brmpkg='brazil ws --remove -p'
alias bcache='brazil-package-cache clean'
alias bvs='brazil ws --use --versionset'
alias bre='brazil-runtime-exec'
alias ninja='ninja-dev-sync'
alias ninjasetup='ninja -setup'
alias gs='git status'
alias gcm='git commit -m'
alias gb='git branch'
alias gc='git checkout'
alias gcb='git checkout -b'
alias gst='git stash'
alias gstp='git stash pop'
alias gl='git log'
alias gd='git diff'
alias gpr='git pull --rebase'
alias ga='git add .'
alias gcall='ga && git commit -a --amend --no-edit'
alias deact='sudo /apollo/bin/runCommand -a Deactivate -e '
alias act='sudo /apollo/bin/runCommand -a Activate -e '
alias assssAAA='sudo /apollo/bin/runCommand -a Activate -e AlexaSkillSearchSpeechletService.CONSUMES.AAASecurityDaemon'
alias ut='python3 -m http.server'
alias bigfile='sudo find / -xdev -type f -size +100000000c -print'
alias aaa="/apollo/env/AAAWorkspaceSupport/bin/register_with_aaa.py -a"
source ~/.zsh/zsh-autosuggestions/zsh-autosuggestions.zsh
[[ -s /home/sonjiang/.autojump/etc/profile.d/autojump.sh ]] && source /home/sonjiang/.autojump/etc/profile.d/autojump.sh
autoload -U compinit && compinit -u
export PATH=$HOME/.toolbox/bin:$PATH
export PATH=/apollo/env/SDETools/bin:$PATH
export BRAZIL_WORKSPACE_DEFAULT_LAYOUT=short
for f in SDETools envImprovement AmazonAwsCli OdinTools; do
if [[ -d /apollo/env/$f ]]; then
export PATH=$PATH:/apollo/env/$f/bin
fi
done
export AUTO_TITLE_SCREENS="NO"
export PROMPT="
%{$fg[white]%}(%D %*) <%?> [%~] $program %{$fg[default]%}
%{$fg[cyan]%}%m %#%{$fg[default]%} "
export RPROMPT=
set-title() {
echo -e "\e]0;$*\007"
}
ssh() {
set-title $*;
/usr/bin/ssh -2 $*;
set-title $HOST;
}
alias timberIAD='sshenv TimberFS/IAD/DeeOpsTimber' #NA Gamma, NA Prod, EU Alpha, EU Beta
alias timberDUB='sshenv TimberFS/DUB/DeeOpsTimber' #EU Gamma, EU Prod
alias timberPDX='sshenv TimberFS/PDX/DeeOpsTimber' #FE Gamma, FE Prod, NA Alpha, NA Beta
if [ -f ~/.zshrc-dev-dsk-post ]; then
source ~/.zshrc-dev-dsk-post
fi
PATH="/usr/NX/bin:/usr/local/bin:/bin:/usr/bin:/home/sonjiang/bin:/usr/local/sbin:/usr/sbin:/sbin:/apollo/env/envImprovement/bin:/apollo/env/AmazonAwsCli/bin:/apollo/env/OdinTools/bin"
alias vim='/apollo/env/envImprovement/bin/vim'
alias ..="cd .."
alias ...="cd ../.."
alias ....="cd ../../.."
alias e=emacs
alias bb=brazil-build
alias bbs='bb server'
alias bws='brazil ws'
alias dryrun='brazil ws --dryrun'
alias e=emacs
alias bb=brazil-build
alias bbs='bb server'
alias bws='brazil ws'
alias dryrun='brazil ws --dryrun'
alias bshow='brazil ws show'
alias bsync='brazil ws sync -md'
alias bclean='bws clean'
alias brmws='brazil ws --delete --root'
alias brmpkg='brazil ws --remove -p'
alias bcache='brazil-package-cache clean'
alias bvs='brazil ws --use --versionset'
alias bre='brazil-runtime-exec'
alias ninja='ninja-dev-sync'
alias ninjasetup='ninja -setup'
alias gs='git status'
alias gcm='git commit -m'
alias gb='git branch'
alias gc='git checkout'
alias gcb='git checkout -b'
alias gst='git stash'
alias gstp='git stash pop'
alias gl='git log'
alias gd='git diff'
alias gpr='git pull --rebase'
alias ga='git add .'
alias gcall='ga && git commit -a --amend --no-edit'
alias deact='sudo /apollo/bin/runCommand -a Deactivate -e '
alias act='sudo /apollo/bin/runCommand -a Activate -e '
alias assssAAA='sudo /apollo/bin/runCommand -a Activate -e AlexaSkillSearchSpeechletService.CONSUMES.AAASecurityDaemon'
alias ut='python3 -m http.server'
alias bigfile='sudo find / -xdev -type f -size +100000000c -print'
alias aaa="/apollo/env/AAAWorkspaceSupport/bin/register_with_aaa.py -a"
source ~/.zsh/zsh-autosuggestions/zsh-autosuggestions.zsh
[[ -s /home/sonjiang/.autojump/etc/profile.d/autojump.sh ]] && source /home/sonjiang/.autojump/etc/profile.d/autojump.sh
autoload -U compinit && compinit -u
export PATH=$HOME/.toolbox/bin:$PATH
export PATH=/apollo/env/SDETools/bin:$PATH
Monday, November 27, 2017
Wednesday, November 22, 2017
Git
版本回退:
git log: 查看提交历史
git log --graph: 查看分支合并图
git reflog: 查看命令历史
git reset --hard commit_id: 回退到了某个版本
git reset --hard HEAD^: 回退到上一个版本
git reset --hard HEAD~10: 回退到之前第十个版本
撤销修改:
git checkout -- file: 可以丢弃工作区的修改(或删除操作), 让file这个文件回到最近一次git commit或git add时的状态
git reset HEAD file: 可以把暂存区的修改撤销掉,重新放回工作区
分支管理:
git merge --no-ff -m <commit-info> <branch-name>: 强制禁用Fast forward模式,Git就会在merge时生成一个新的commit,从分支历史上就可以看出分支信息
git stash: 把当前工作现场“储存”起来
git stash apply: 恢复储存的内容,但是恢复后,stash内容并不删除
git stash drop: 删除stash的内容
git stash pop: 恢复的同时把stash内容也删了
git stash apply stash@{0}: 如果有多次stash的话,选择恢复某个stash内容
配置别名:
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
实际工作:
git checkout mainline
git pull
git checkout dev
git rebase mainline
(resolve conflicts + commit)
git checkout mainline
git merge dev
git push origin mainline
git log: 查看提交历史
git log --graph: 查看分支合并图
git reflog: 查看命令历史
git reset --hard commit_id: 回退到了某个版本
git reset --hard HEAD^: 回退到上一个版本
git reset --hard HEAD~10: 回退到之前第十个版本
撤销修改:
git checkout -- file: 可以丢弃工作区的修改(或删除操作), 让file这个文件回到最近一次git commit或git add时的状态
git reset HEAD file: 可以把暂存区的修改撤销掉,重新放回工作区
分支管理:
git merge --no-ff -m <commit-info> <branch-name>: 强制禁用Fast forward模式,Git就会在merge时生成一个新的commit,从分支历史上就可以看出分支信息
git stash: 把当前工作现场“储存”起来
git stash apply: 恢复储存的内容,但是恢复后,stash内容并不删除
git stash drop: 删除stash的内容
git stash pop: 恢复的同时把stash内容也删了
git stash apply stash@{0}: 如果有多次stash的话,选择恢复某个stash内容
配置别名:
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
实际工作:
git checkout mainline
git pull
git checkout dev
git rebase mainline
(resolve conflicts + commit)
git checkout mainline
git merge dev
git push origin mainline
Friday, October 6, 2017
Sliding Window Second Maximum
Given an array nums, there is a sliding window of size k which is moving from the very left of the array to the very right. You can only see the k numbers in the window. Each time the sliding window moves right by one position.
For example:
Given nums =
Then, return the second max sliding window [1, -1, -1, 3, 5, 6] .
/* time: amortized O(n), space:O(n) */
import java.util.*;
public class Solution {
public static int[] test(int[] nums, int k) {
if (nums == null || nums.length <= 1 || k <= 1) {
return nums;
}
if (k > nums.length) {
k = nums.length;
}
int[] res = new int[nums.length - k + 1];
Deque<Integer> deque = new ArrayDeque<>();
int maxNumIndex = 0;
int index = 0;
for (int i = 1; i < nums.length; i++) {
if (!deque.isEmpty() && deque.peek() < i - k + 1) {
deque.poll();
}
if (maxNumIndex < i - k + 1) {
maxNumIndex = deque.poll();
}
if (nums[i] > nums[maxNumIndex]) {
int temp = maxNumIndex;
maxNumIndex = i;
while (!deque.isEmpty() && temp > deque.peek()) {
deque.poll();
}
deque.offerFirst(temp);
} else {
while (!deque.isEmpty() && nums[i] > nums[deque.peekLast()]) {
deque.pollLast();
}
deque.offer(i);
}
if (i >= k - 1) {
res[index++] = nums[deque.peek()];
}
}
return res;
}
public static void main(String[] args) {
int[] nums = {1, 3, -1, -3, 5, 3, 6, 7};
int[] t0 = test(nums, 1);
int[] t1 = test(nums, 2);
int[] t2 = test(nums, 3);
int[] t3 = test(nums, 4);
int[] t4 = test(nums, 5);
int[] t5 = test(nums, 6);
int[] t6 = test(nums, 7);
int[] t7 = test(nums, 8);
int[] t8 = test(nums, 9);
int[] t9 = test(nums, 10);
System.out.println(Arrays.toString(t0));
System.out.println(Arrays.toString(t1));
System.out.println(Arrays.toString(t2));
System.out.println(Arrays.toString(t3));
System.out.println(Arrays.toString(t4));
System.out.println(Arrays.toString(t5));
System.out.println(Arrays.toString(t6));
System.out.println(Arrays.toString(t7));
System.out.println(Arrays.toString(t8));
System.out.println(Arrays.toString(t9));
}
}
For example:
Given nums =
[1,3,-1,-3,5,3,6,7]
, and k = 3. Then, return the second max sliding window [1, -1, -1, 3, 5, 6] .
/* time: amortized O(n), space:O(n) */
import java.util.*;
public class Solution {
public static int[] test(int[] nums, int k) {
if (nums == null || nums.length <= 1 || k <= 1) {
return nums;
}
if (k > nums.length) {
k = nums.length;
}
int[] res = new int[nums.length - k + 1];
Deque<Integer> deque = new ArrayDeque<>();
int maxNumIndex = 0;
int index = 0;
for (int i = 1; i < nums.length; i++) {
if (!deque.isEmpty() && deque.peek() < i - k + 1) {
deque.poll();
}
if (maxNumIndex < i - k + 1) {
maxNumIndex = deque.poll();
}
if (nums[i] > nums[maxNumIndex]) {
int temp = maxNumIndex;
maxNumIndex = i;
while (!deque.isEmpty() && temp > deque.peek()) {
deque.poll();
}
deque.offerFirst(temp);
} else {
while (!deque.isEmpty() && nums[i] > nums[deque.peekLast()]) {
deque.pollLast();
}
deque.offer(i);
}
if (i >= k - 1) {
res[index++] = nums[deque.peek()];
}
}
return res;
}
public static void main(String[] args) {
int[] nums = {1, 3, -1, -3, 5, 3, 6, 7};
int[] t0 = test(nums, 1);
int[] t1 = test(nums, 2);
int[] t2 = test(nums, 3);
int[] t3 = test(nums, 4);
int[] t4 = test(nums, 5);
int[] t5 = test(nums, 6);
int[] t6 = test(nums, 7);
int[] t7 = test(nums, 8);
int[] t8 = test(nums, 9);
int[] t9 = test(nums, 10);
System.out.println(Arrays.toString(t0));
System.out.println(Arrays.toString(t1));
System.out.println(Arrays.toString(t2));
System.out.println(Arrays.toString(t3));
System.out.println(Arrays.toString(t4));
System.out.println(Arrays.toString(t5));
System.out.println(Arrays.toString(t6));
System.out.println(Arrays.toString(t7));
System.out.println(Arrays.toString(t8));
System.out.println(Arrays.toString(t9));
}
}
Wednesday, October 4, 2017
Word Search
Given a 2D board and a word, find if the word exists in the grid.
The word can be constructed from letters of sequentially adjacent cell, where "adjacent" cells are those horizontally or vertically neighboring. The same letter cell may not be used more than once.
For example,
Given board =
Given board =
[ ['A','B','C','E'], ['S','F','C','S'], ['A','D','E','E'] ]word =
"ABCCED"
, -> returns true
,word =
"SEE"
, -> returns true
,word =
"ABCB"
, -> returns false
./* method 1:
* time:O(m*n*4^L), space:O(m*n), m: board's row, n: board's column, L: word size
* Imagine this is a tree, this quadtree's height is L(L is length of word) and its total node number is
*
4^0 + 4^1 + ... + 4^L = 1/3 * ( 4^(L+1) - 1 )
. So the time complexity of this dfs solution is * mnO(4^L)
.*/
public class Solution {
public boolean exist(char[][] board, String word) {
char[] words = word.toCharArray();
int width = board.length;
int length = board[0].length;
boolean[][] visited = new boolean[width][length];
for (int y = 0; y < width; y++) {
for (int x = 0; x < length; x++) {
if (exist(board, y, x, words, 0, visited)) {
return true;
}
}
}
return false;
}
private boolean exist(char[][] board, int y, int x, char[] words, int i, boolean[][] visited) {
if (i == words.length) {
return true;
}
if (y < 0 || x < 0 || y == board.length || x == board[y].length || visited[y][x] == true) {
return false;
}
if (board[y][x] != words[i]) {
return false;
}
visited[y][x] = true;
boolean exist = exist(board, y, x + 1, words, i + 1, visited)
|| exist(board, y, x - 1, words, i + 1, visited)
|| exist(board, y + 1, x, words, i + 1, visited)
|| exist(board, y - 1, x, words, i + 1, visited);
visited[y][x] = false;
return exist;
}
}
/* method2:
* time:O(m*n*4^L), space:O(1)
*
* board[y][x] ^= 256 it's a marker that the letter at position x,y is a part of word we search.
* After board[y][x] ^= 256 the char became not a valid letter. After second board[y][x] ^= 256
* it became a valid letter again.
*/
public class Solution {
public boolean exist(char[][] board, String word) {
char[] words = word.toCharArray();
int row = board.length;
int column = board[0].length;
for (int y = 0; y < row; y++) {
for (int x = 0; x < column; x++) {
if (exist(board, y, x, words, 0)) {
return true;
}
}
}
return false;
}
private boolean exist(char[][] board, int y, int x, char[] words, int i) {
if (i == words.length) {
return true;
}
if (y < 0 || x < 0 || y == board.length || x == board[y].length) {
return false;
}
if (board[y][x] != words[i]) {
return false;
}
board[y][x] ^= 256;
boolean exist = exist(board, y, x + 1, words, i + 1)
|| exist(board, y, x - 1, words, i + 1)
|| exist(board, y + 1, x, words, i + 1)
|| exist(board, y - 1, x, words, i + 1);
board[y][x] ^= 256;
return exist;
}
}
Monday, October 2, 2017
K closest points
/*
* Find the K closest points to the origin in 2D plane, given an array containing N points.
* You can assume K is much smaller than N and N is very large.
* You need only use standard math operators (addition, subtraction, multiplication, and division).
*/
import java.util.*;
class Point {
double x;
double y;
public Point(double x, double y) {
this.x = x;
this.y = y;
}
}
public class Solution {
private static double distance(Point a, Point b) {
return (a.x - b.x) * (a.x - b.x) + (a.y - b.y) * (a.y - b.y);
}
public static Point[] closestPoint(Point[] array, final Point origin, int k) {
if (k >= array.length) {
// return array;
k = array.length;
}
if (k <= 0) {
return new Point[0];
}
Point[] res = new Point[k];
PriorityQueue<Point> maxHeap = new PriorityQueue<>(k + 1, new Comparator<Point>() {
@Override
public int compare(Point a, Point b) {
return Double.compare(distance(b, origin), distance(a, origin));
}
});
for(Point p : array) {
maxHeap.offer(p);
if (maxHeap.size() > k) {
maxHeap.poll();
}
}
for(int i = k - 1; i >= 0; i--) {
res[i] = maxHeap.poll();
}
return res;
}
public static void main(String[] args) {
Point origin = new Point(0, 0);
Point[] input = new Point[]{new Point(0, 2), new Point(1, 1), new Point(-1, 0), new Point(2, 0), new Point(3, 0)};
Point[] output = closestPoint(input, origin, 3);
System.out.println("input");
for(Point i : input) System.out.print("("+i.x+", "+i.y+") ");
System.out.println("");
System.out.println("output");
for(Point i : output) System.out.print("("+i.x+", "+i.y+") ");
}
}
* Find the K closest points to the origin in 2D plane, given an array containing N points.
* You can assume K is much smaller than N and N is very large.
* You need only use standard math operators (addition, subtraction, multiplication, and division).
*/
import java.util.*;
class Point {
double x;
double y;
public Point(double x, double y) {
this.x = x;
this.y = y;
}
}
public class Solution {
private static double distance(Point a, Point b) {
return (a.x - b.x) * (a.x - b.x) + (a.y - b.y) * (a.y - b.y);
}
public static Point[] closestPoint(Point[] array, final Point origin, int k) {
if (k >= array.length) {
// return array;
k = array.length;
}
if (k <= 0) {
return new Point[0];
}
Point[] res = new Point[k];
PriorityQueue<Point> maxHeap = new PriorityQueue<>(k + 1, new Comparator<Point>() {
@Override
public int compare(Point a, Point b) {
return Double.compare(distance(b, origin), distance(a, origin));
}
});
for(Point p : array) {
maxHeap.offer(p);
if (maxHeap.size() > k) {
maxHeap.poll();
}
}
for(int i = k - 1; i >= 0; i--) {
res[i] = maxHeap.poll();
}
return res;
}
public static void main(String[] args) {
Point origin = new Point(0, 0);
Point[] input = new Point[]{new Point(0, 2), new Point(1, 1), new Point(-1, 0), new Point(2, 0), new Point(3, 0)};
Point[] output = closestPoint(input, origin, 3);
System.out.println("input");
for(Point i : input) System.out.print("("+i.x+", "+i.y+") ");
System.out.println("");
System.out.println("output");
for(Point i : output) System.out.print("("+i.x+", "+i.y+") ");
}
}
Monday, May 1, 2017
Implement a fix-sized queue using array
Implement a fix-sized queue using array.
import java.util.*;
public class Queue<T> {
private int front;
private int rear;
private int size;
private final T[] queue;
public Queue(int capacity) {
if (capacity <= 0) {
throw new IllegalArgumentException("Size cannot be less than or equal to zero.");
}
size = 0;
front = 0;
rear = -1;
queue = (T[])new Object[capacity];
}
public int size() {
return size;
}
public void enQueue(T item) {
if (size == queue.length) {
throw new IllegalStateException("Queue is full.");
}
rear = (rear + 1) % queue.length;
queue[rear] = item;
size++;
}
public T deQueue() {
if (isEmpty()) {
throw new IllegalStateException("Queue is empty.");
}
T value = queue[front];
front = (front + 1) % queue.length;
size--;
return value;
}
public boolean isEmpty() {
return size == 0;
}
public T peek() {
if (isEmpty()) {
throw new IllegalStateException("Queue is Empty.");
}
return queue[front];
}
@Override
public String toString() {
int s = size;
int head = front;
String str = "[";
while (s > 1) {
str += queue[head];
str += ", ";
s--;
head = (head + 1) % queue.length;
}
if (s == 1) {
str += queue[head];
}
str += "]";
return str;
}
public static void main(String[] args) {
Queue<Integer> newQueue = new Queue<>(5);
newQueue.enQueue(10);
newQueue.enQueue(20);
newQueue.enQueue(30);
newQueue.enQueue(40);
newQueue.enQueue(50);
System.out.println(newQueue.toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.toString());
newQueue.enQueue(60);
newQueue.enQueue(70);
System.out.println("Size should be 5, the result is " + newQueue.size());
System.out.println("Should be false, the result is " + newQueue.isEmpty());
System.out.println(newQueue.toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.toString());
System.out.println("Size should be 0, the result is " + newQueue.size());
System.out.println("Should be true, the result is " + newQueue.isEmpty());
}
}
import java.util.*;
public class Queue<T> {
private int front;
private int rear;
private int size;
private final T[] queue;
public Queue(int capacity) {
if (capacity <= 0) {
throw new IllegalArgumentException("Size cannot be less than or equal to zero.");
}
size = 0;
front = 0;
rear = -1;
queue = (T[])new Object[capacity];
}
public int size() {
return size;
}
public void enQueue(T item) {
if (size == queue.length) {
throw new IllegalStateException("Queue is full.");
}
rear = (rear + 1) % queue.length;
queue[rear] = item;
size++;
}
public T deQueue() {
if (isEmpty()) {
throw new IllegalStateException("Queue is empty.");
}
T value = queue[front];
front = (front + 1) % queue.length;
size--;
return value;
}
public boolean isEmpty() {
return size == 0;
}
public T peek() {
if (isEmpty()) {
throw new IllegalStateException("Queue is Empty.");
}
return queue[front];
}
@Override
public String toString() {
int s = size;
int head = front;
String str = "[";
while (s > 1) {
str += queue[head];
str += ", ";
s--;
head = (head + 1) % queue.length;
}
if (s == 1) {
str += queue[head];
}
str += "]";
return str;
}
public static void main(String[] args) {
Queue<Integer> newQueue = new Queue<>(5);
newQueue.enQueue(10);
newQueue.enQueue(20);
newQueue.enQueue(30);
newQueue.enQueue(40);
newQueue.enQueue(50);
System.out.println(newQueue.toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.toString());
newQueue.enQueue(60);
newQueue.enQueue(70);
System.out.println("Size should be 5, the result is " + newQueue.size());
System.out.println("Should be false, the result is " + newQueue.isEmpty());
System.out.println(newQueue.toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.deQueue().toString());
System.out.println(newQueue.toString());
System.out.println("Size should be 0, the result is " + newQueue.size());
System.out.println("Should be true, the result is " + newQueue.isEmpty());
}
}
Thursday, March 23, 2017
Roman to Integer
/*
Given a roman numeral, convert it to an integer.
Input is guaranteed to be within the range from 1 to 3999.
*///time: O(n), space:O(1)
public class Solution {
public int romanToInt(String s) {
if (s == null || s.length() == 0) {
return 0;
}
Map<Character, Integer> map = new HashMap<>();
map.put('I', 1);
map.put('V', 5);
map.put('X', 10);
map.put('L', 50);
map.put('C', 100);
map.put('D', 500);
map.put('M', 1000);
int res = map.get(s.charAt(s.length() - 1));
for (int i = s.length() - 2; i >= 0; i--) {
if (map.get(s.charAt(i)) >= map.get(s.charAt(i + 1))) {
res += map.get(s.charAt(i));
} else {
res -= map.get(s.charAt(i));
}
}
return res;
}
}
Subscribe to:
Posts (Atom)