昆山如何更好的学习java

预约试听

课程介绍

发布时间:2018-10-22
昆山如何更好的学习java
其然IT 教育师资

李明杰(MJ)高级讲师

多年软件开发经验和教学经验,尤其精通Android和iOS平台的开发,还开发了2个iOS的流行开源框架(MJRefresh、MJExtension), 目前在国内的使用率非常高。

李老师曾负责主导开发过装饰ERP系统手机端、服装连锁管理系统手机及平板客户端、自动鸡尾酒调酒机系统、网络斗地主RPG、游戏 引擎等。曾以架构师及技术总监的角色帮客户成功获得多家风投,并上了中央电视台《给你一个亿》节目。除了Android和iOS平台,李老师也深入研究 HTML5、phoneGap、Sencha-Touch、Less、Bootstrap、AngularJS、NodeJS等前端利器。

2015年8月 CCTV发现之旅《华商论见》栏目特约嘉宾,受邀参加节目《互联网 浪潮下的创业之道》,接受央视著名主持人水均益采 访。2015年10月 曾受邀加入中国经贸代表团随总理出访韩国,参与总理访韩午餐会以及中日韩工商峰会。2015年12月 荣获中国经济新模 式创新与发展峰会“2015中国IT教育培训行业**具创新人物”奖。

李老师不但具有丰富的软件开发经验,并且懂得如何把自己掌握的知识及技能传授给他人,曾给多家企业提供Android/iOS技术培训 、技术支持、技术咨询等服务。李老师的授课视频深得学生们的喜爱,已培养出好几千名iOS程序员。


昆山如何更好的学习java

java入门要注意什么

昆山如何更好的学习java

学习java就像是一个种花的过程,不断地为其施肥浇水,它才会茁壮成长。 而我们学习java,就要不断的充实自己、提升自己,才能获得更多机会。很多开始学习java编程的小白,经常就会被概念、定义什么的搞糊涂。当分类 、对象、接口、构造函数等等各种专业名词出现的时候,你一定是脑子里好像一片空白,根本就搞不懂这些字眼的意思和关系,而且,这种情况下,很 容易导致你丧失自信心,开始逃避、拒绝,这些小白经常遇到的情况在我刚接触java的时候也遇见了,但是好在我足够幸运,遇见了诚筑说。我现在已 经是公司的项目经理了,今天,我为大家来总结了一些经验和建议,希望能够帮助到大家。

一点:熟练基本的j2seAPI

除去java语言本身的语法之外呢,要懂得并且熟练j2seAPI的API也是非常有 必要的,在这里,就建议大家首先去掌握字符串的处理、异常的处理、容器、输入输出、线程等,这些相对来说较为重要的。还有就是API的内容是非 常庞大的,关于API,一定要懂得查询API的文件说明,在了解了其作用用途或者目的才能够进行相对于的程序。

二点:稳固java的语法基础

学习java一定要学会使用java的程序语言,用来编写程序,但是学习程序语 言就要熟悉语法是怎么使用的。程序语言其实也是一种语言,不过跟人类的语言不同,这种语言是要和计算机沟通交流,那怎么做才能熟悉这种语言呢 ,我给出的建议是多看别人写的程序,了解人家是怎么用java来解决问题的。然后再找类似的程序去练习了,这样就能够从实际操作中检验自己是否真 的知道该怎么去解决问题了。

三点:加入贴吧论坛多参与讨论

根据我当时的经验,在大家学习的过程中,如果有人可以参与话题,共同讨 论的话,会加快你学习的速度。所以大家可以和我一样,找一个技术讨论的地方,贴吧啊,论坛啊都可以,在这里进行讨论,毕竟大家有着共同的目标 和理想,有着共同的话题可聊,这样的话,又大大节省了学习的时间。

学完基本的java语法呢,现在就该用java来进行实际的编程了,假如你需要 编写窗口程序,那就学Swing窗口设计;假如你要编写数据库什么的,那就学JDBC等等。

流行框架

昆山如何更好的学习java

流行框架

  • 01Struts2

    • 1.Struts2流程

    • 2.值栈与ONGL

    • 3.Struts2标签库

    • 4.Struts2模型驱动原理

    • 5.Struts2声明式异常处理

    • 6.Struts2类型转换&自定义类型转换

    • 7.Struts2拦截器原理&自定义拦截器

    • 8.Struts2源码分析&运行原理

  • 02Hibernate

    • 1.Hibernate环境搭建&配置

    • 2.hibernate.cfg.xml&主键生成策略

    • 3.Session核心方法

    • 4.ORM映射:单向/双向1-n映射

    • 5.ORM映射:基于主/外键映射&n-n

    • 6.检索策略&迫切左外连接

    • 7.Hibernate缓存机制

    • 8.QBC、HQL

    • 9.Session管理

  • 03Spring

    • 1.SpringIOC&DI机制

    • 2.Spring配置式组件管理

    • 3.Spring注解式自动装配

    • 4.Spring表达式语言

    • 5.SpringAOP&动态代理

    • 6.SpringJDBC使用

    • 7.Spring声明式事务

    • 8.Spring单元测试

    • 9.Spring源码分析

    • 10.Spring、Struts2、Hibernate整合

  • 04SpringMVC

    • 1.SpringMVC配置&运行流程

    • 2.SpringMVC数据绑定

    • 3.模型处理&@ModelAttribute

    • 4.RestFulCRUD

    • 5.表单标签&静态资源处理

    • 6.数据转换&格式化&JSR303数据校验

    • 7.HttpMessageConverter

    • 8.Ajax&国际化&文件上传**

    • 9.异常处理

    • 10.整合&父子容器

  • 05MyBatis

    • 1.MyBatis配置&查询数据

    • 2.MyBatis全局配置文件

    • 3.MyBatis映射文件

    • 4.关联查询,动态sql

    • 5.MyBatis缓存机制&整合ehcache

    • 6.MyBatis逆向工程

    • 7.MyBatis、Spring、SpringMVC整合

    • 8.MyBatis运行原理&源码分析

    • 9.MyBatis拦截器&插件开发

    • 10.分页插件&存储过程调用&自定义 TypeHandler

  • 06JPA

    • 1.JPA技术体系

    • 2.JPA注解

    • 3.JPA相关API

    • 4.JPA映射

    • 5.JPQL

    • 6.二级缓存

    • 7.Spring整合JPA

  • 07SpringData

    • 1.SpringData快速入门

    • 2.SpringData_Repository接口

    • 3.Repository查询规范

    • 4.@Query&@Modifying

    • 5.CrudRepository

    • 6.PagingAndSortingRepository

    • 7.JpaRepository

    • 8.JpaSpecificationExecutor

    • 9.自定义Repository

  • 08Maven

    • 1.Maven环境搭建

    • 2.Maven构建&自动化构建

    • 3.本地仓库&中央仓库

    • 4.maven创建web工程

    • 5.pom.xml、依赖管理

    • 6.坐标、依赖、生命周期等

    • 7.eclipse下的maven使用

    • 8.继承&聚合

    • 9.maven构建SSH/SSM应用

    • 10.自动部署&持续集成&持续部署

  • 09SVN

    • 1.SVN简介

    • 2.SVN服务器搭建

    • 3.SVN创建版本库

    • 4.Eclipse整合svn插件

    • 5.使用SVN更新提交

    • 6.SVN仓库分析

    • 7.SVN协同修改&冲突解决

    • 8.SVN权限管理

    • 9.SVN时光机

    • 10.TortoiseSVN

  • 10Shiro

    • 1.Shiro入门

    • 2.Spring集成Shiro

    • 3.Shiro工作流程

    • 4.权限URL配置

    • 5.认证流程&认证Realm

    • 6.密码比对,MD5&盐值加密

    • 7.授权流程

    • 8.标签&权限注解

    • 9.会话管理、SessionDao

    • 10.缓存

    • 11.实现”记住我”

  • 11Activiti5

    • 1.工作流&工作流引擎

    • 2.BPMN2.0规范

    • 3.Activiti5框架表结构

    • 4.Activiti5核心组件&服务接口

    • 5.Activiti5插件安装&整合Spring

    • 6.流程定义

    • 7.流程实例&任务&历史

    • 8.任务领取&流程变量

    • 9.排他网关&并行网关

  • 12WebService

    • 1.WebService简介

    • 2.WebService主流框架

    • 3.cxf的使用

    • 4.SOAP协议

    • 5.WSDL讲解

    • 6.JAX-WS

    • 7.与Spring整合

    • 8.JAXB

    • 9.JAX-RS

    • 10.支付接口原理

  • 13Linux

    • 1.Linux系统-基础

    • 2.Linux网络基础

    • 3.Linux在VMware下的安装

    • 4.Linux下Java环境的搭建

    • 5.Linux下Tomcat安装和配置

    • 6.Linux下 Oracle/MySQL 安装与配置

    • 7.Shell 编程

  • 14Redis

    • 1.NoSQL&Redis入门

    • 2.Redis/memcache/MongDB对比

    • 3.Redis安装&启动

    • 4.分布式数据库CAP原理

    • 5.Redis五大数据类型和基本操作命令

    • 6.Redis总体配置Redis.conf

    • 7.Redis持久化(RDB和AOF)

    • 8.Redis事务控制

    • 9.Redis发布和订阅

    • 10.Redis(Master/Slave)主从复制

    • 11.Jedis

  • 15Git&Git Hub

    • 1.Git安装配置

    • 2.Git本地库搭建

    • 3.Git常用操作命令

    • 4.Github注册与配置

    • 5.Github与Git协同办公

    • 6.TortoiseGit安装配置

    • 7.Egit操作push/pull,

    • 8.Git工作流

    • 9.集中式&GitFlow&Forking

  • 16MySQL高级

    • 1.MySQL架构组成

    • 2.MySQL备份和恢复

    • 3.MySQL查询和慢查询日志分析

    • 4.MySQL索引优化

    • 5.MySQL存储引擎优化

    • 6.MySQL锁机制优化

    • 7.MySQL高可用设计

    • 8.MySQL集群

  • 17JVM原理

    • 1.JVM简析

    • 2.JVM组成结构

    • 3.JVM堆、栈原理

    • 4.JVM-Heap三区原理

    • 5.JVM垃圾收集机制

    • 6.堆内存调优

    • 7.GC回收策略

    • 8.GC三大算法

  • 18Quartz

    • 1.Quartz作业调度简介

    • 2.Quartz作业调度执行以及持久性

    • 3.Quartz基本使用

    • 4.Quartz核心类讲解

    • 5.Quartz Trigger 触发器

    • 6.Quartz Job&JobDetail

    • 7.Quartz Calendars日历讲解

    • 8.JobListener监听器和TriggerListener监听器

    • 9.Spring整合Quartz

  • 19Nginx

    • 1.Nginx反向代理介绍

    • 2.Nginx **和安装

    • 3.Nginx 编译和启动、访问

    • 4.在Linux下搭建Nginx集群

    • 5.在Windows搭建Nginx集群

    • 6.解决Session共享问题

  • 20Java JUC 线程高级

    • 1.volatile 关键字

    • 2.内存可见性分析

    • 3.原子变量与CAS (Compare And Swap) 算法分 析

    • 4.ConcurrentHashMap 锁分段机制

    • 5.CountDownLatch 闭锁

    • 6.实现 Callable 接口

    • 7.Lock 同步锁

    • 8.Condition 控制线程通信

    • 9.线程按序交替

HDU 2586 How far away ?(map lca【暴力水】)


>

题目链接:http://acm.hdu.edu.cn/showPRoblem.php?pid=2586

How far away ?

Time Limit: 2000/1000 MS (java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 14305 Accepted Submission(s): 5409

Problem Description There are n houses in the village and some bidirectional roads connecting them. Every day peole always like to ask like this “How far is it if I want to go from house A to house B”? Usually it hard to answer. But luckily int this village the answer is always unique, since the roads are built in the way that there is a unique simple path(“simple” means you can’t visit a place twice) between every two houses. Yout task is to answer all these curious people.

Input First line is a single integer T(T<=10), indicating the number of test cases. For each test case,in the first line there are two numbers n(2<=n<=40000) and m (1<=m<=200),the number of houses and the number of queries. The following n-1 lines each consisting three numbers i,j,k, separated bu a single space, meaning that there is a road connecting house i and house j,with length k(0< k<=40000).The houses are labeled from 1 to n. Next m lines each has distinct integers i and j, you areato answer the distance between house i and house j.

Output For each test case,output m lines. Each line represents the answer of the query. Output a bland line after each test case.

Sample Input 2 3 2 1 2 10 3 1 15 1 2 2 3

2 2 1 2 100 1 2 2 1

Sample Output 10 25 100 100

Source ECJTU 2009 Spring Contest

【中文题意】有t组数据,每组数据一个n,一个m,n代表点的个数,m代表询问的次数。 下面n-1行每行输入三个整数i,j,k,意思为,从i到j有一条长度为k的双向边。 下面m行每行两个整数u,v;让你输出从u到v的**短距离。 【思路分析】运用lca的思想,以1为树根DFS建立树,记录每个结点的深度和父结点。 用map记录彼此之间的距离。 求的时候直接用暴力求LCA的方法求出距离即可【貌似没有向我这么做的】。 【AC代码】

#include<cstdio> #include<iostream> #include<cstring> #include<cmath> #include<queue> #include<stack> #include<map> #include<algorithm> using namespace std; int t,n,q; vector<int>G[50005]; #define root 1 int parent[50005]; int depth[50005]; map<int,map<int,int> >m; void dfs(int v,int p,int d) { parent[v]=p; depth[v]=d; for(int i=0; i<G[v].size(); i ) { if(G[v][i]!=p) { dfs(G[v][i],v,d 1); } } } void init() { dfs(root,-1,0); } int lca(int u,int v) { int sum=0; while(depth[u]>depth[v]) { sum =m[u][parent[u]]; u=parent[u]; } while(depth[v]>depth[u]) { sum =m[v][parent[v]]; v=parent[v]; } while(u!=v) { sum =m[v][parent[v]]; sum =m[u][parent[u]]; u=parent[u]; v=parent[v]; } return sum; } int main() { scanf("%d",&t); while(t--) { m.clear(); for(int i=0;i<n;i ) { G[i].clear(); } scanf("%d%d",&n,&q); int u,v,cost; for(int i=0; i<n-1; i ) { scanf("%d%d%d",&u,&v,&cost); G[u].push_back(v); G[v].push_back(u); m[u][v]=cost; m[v][u]=cost; //printf("%d**\n",m[u][v]); } init(); for(int i=1; i<=q; i ) { scanf("%d%d",&u,&v); printf("%d\n",lca(u,v)); } } return 0; }


相关推荐:


苏州JAVA培训   苏州JAVA培训班   苏州JAVA培训机构

上一篇:昆山java学习
下一篇:太仓java大数据怎么学习

昆山如何更好的学习java

课程价格:¥详询 市场价:¥详询

预约试听

其他试听课程

机构全部课程

有问题请留言

Copyright © 2006-2018 kaoshi.china.com