java基础语法难点(day01-day05)

2024-05-20 19:58

本文主要是介绍java基础语法难点(day01-day05),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

学学高级语言,面向对象的语言,和c语言比起来,前面的语法还是有一定的相似度的,所以,在学习面向对象之前,简单的把java的一些常用的基础语法过一遍,相当于复习了。

有个隐形的类型转换,但是就是小的转到大的,可以。但是如果是int数据类型转到小一点的short去,不强制类型转换就会溢出报错。

注意+=这个扩展运算符是可以接受类型转换的,所以不会报错。

三元运算符中的三个数比较最大值:

int a = 10;
int b = 20;
int c = 30;
int max = (a>b)?a:b;
max = (max>c)?max:c;//通过两次使用三元运算符来判断最大值。 

和c语言一样,要注意自增和自减,a++是赋值不会+,在后面才会,++a是赋值的时候就已经加了。

还有&, &&,|,||。逻辑与和短路与,逻辑或和短路或他们的优缺点要知道。

和c语言不同的是要从键盘上输入的时候需要写

import java.util.*;//主义是小写的import
Scanner scanner = new Scanner(System.in);
int name = scanner.nextInt();

流程语句也是类似,不管是什么问题,水仙花,还是珠穆朗玛峰折纸。算法其实不是最重要的,这里的语法才是,如果写嵌套,具体循环的条件哪三个要清楚,不能越界。


最重要的还是函数和数组,因为我们不可能在一个主函数里面完成任何需求,所以一旦需要,我们要通过封装一段程序,下次我们需要的时候就可以调用。

函数的使用注意事项:
1.函数中只能调用函数,不能定义函数,没有定义函数之前,不能调用函数。
2.输出语句只能对有具体返回结果的函数的进行打印。
3.返回值类型是void的函数,是不可以被输出语句打印的。
4.函数需要实现功能,那么函数只实现所需功能即可,不要实现不需要的功能。

对于数组,需要注意的是栈和堆中内存的分布情况。

下面主要是要举排序的例子:
1.直接排序(选择排序)
思路:使用索引值为0的元素与其他未知的元素挨个比较一次,如果有发现比0号索引值元素大的,那么交换位置。大的在前,小的在后。

/*选择排序。以一个角标的元素和其他元素进行比较。在内循环第一次结束,最值出现的头角标位置上。*/public static void selectSort(int[] arr){for(int x=0; x<arr.length-1; x++){for(int y=x+1; y<arr.length; y++)//为什么y的初始化值是 x+1?因为每一次比较,都用x角标上的元素和下一个元素进行比较。因为第一个位置在外层循环中已经确定了。所以不用再比较{if(arr[x]>arr[y]){int temp = arr[x];arr[x] = arr[y];arr[y] = temp;}}}} 

2.冒泡排序
思路:相邻的两个元素挨个比较,大的元素放右边,小的放左边。

 /*冒泡排序。比较方式:相邻两个元素进行比较。如果满足条件就进行位置置换。原理:内循环结束一次,最值出现在尾角标位置。*/public static void bubbleSort(int[] arr){for(int x=0; x<arr.length-1; x++)//避免越界{for(int y=0; y<arr.length-x-1; y++)//-x:让每次参与比较的元减-1:避免角标越界。因为外层循环第一个已经确定好了位置,内层循环就需要把外层的x减去,把剩下的几个元素进行排序就可以{if(arr[y]>arr[y+1]){int temp = arr[y];arr[y] = arr[y+1];arr[y+1] = temp;}}}
}

3.折半查找(二分法)
思路:定义三个变量分别记录要查找元素的范围最大索引值,最小索引值,中间索引值,每次都是使用中间索引值的元素与目标元素币交一次,如果不是我们所需要的元素,那么缩小查找的范围。

/*为了提高查找效率,可使用折半查找的方式,注意:这种查找只对有序的数组有效。这种方式也成为二分查找法。*/public static int halfSeach(int[] arr,int key){int min,mid,max;min = 0;max = arr.length-1;mid = (max+min)/2;while(arr[mid]!=key){if(key>arr[mid])min = mid + 1;else if(key<arr[mid])max = mid - 1;if(min>max)return -1;mid = (max+min)/2;}return mid;}

就相当于你要从一本电话簿里面查找一个人的电话,A-Z,你要找m开头的,那么你自己肯定先从中间开始翻起,看到的是G,那么肯定是比目标的M要小所以你就要再往后面翻一翻,但是翻到了R,翻过了,所以得往前翻一翻,这样二分查找法就是比较目标(mid)与最大最小的关系,最终相等了就是结果。

4.数组翻转

/*反转其实就是头角标和尾角标的元素进行位置的置换,然后在让头角标自增。尾角标自减。当头角标<尾角标时,可以进行置换的动作。*/public static void reverseArray(int[] arr){for(int start=0,end=arr.length-1; start<end; start++,end--){swap(arr,start,end);}}//对数组的元素进行位置的置换。public static void swap(int[] arr,int a,int b){int temp = arr[a];arr[a] = arr[b];arr[b] = temp;}

这篇关于java基础语法难点(day01-day05)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/995935

相关文章

一篇文章带你快速入门java

文章目录 一、一个简单的java代码1.1 Java程序的结构由三个不成组成:1.2 运行java程序1.3 JDK,JRE,JVM之间的关系?(面试题)1.4 标识符1.5 注释1.6 关键字 一、一个简单的java代码 public class HelloJava {public static void main(String[] args) {System.out.

Java面试题:内存管理、类加载机制、对象生命周期及性能优化

1. 说一下 JVM 的主要组成部分及其作用? JVM包含两个子系统和两个组件:Class loader(类装载)、Execution engine(执行引擎)、Runtime data area(运行时数据区)、Native Interface(本地接口)。 Class loader(类装载):根据给定的全限定名类名(如:java.lang.Object)装载class文件到Runtim

Shell语法全解

Shell基础语法全解 一、shell简介二、shell格式2.1 新建一个shell脚本文件2.2 执行脚本方式 三、变量3.1系统变量3.2自定义变量3.3 特殊变量3.3.1 `$n` 传入变量3.3.2 `$#` 输入参数个数3.3.3 `$*`、`$@` 输入参数内容3.3.4 `$?` 上一条命令执行结果 四、运算符 `$[]`、`$(())`五、条件判断5.1判断数值大小5.

Javassist使用指南1

1.创建了一个非默认的classpool,加入当前线程的上下文类加载器作为额外的类搜索路径 val classPool = ClassPool(false)classPool.appendClassPath(LoaderClassPath(contextClassLoader)) ClassPool ClassPool是CtClass对象的容器,每一个CtClass对象都必须从Class

使用ig507金融数据库的股票API接口经验有感:Java与Python

一、Java技术: 1. Java调用ig507金融数据库(ig507.com)股票API接口 引言: 随着金融科技的不断发展,数据驱动的投资策略变得越来越重要。本文将介绍如何使用Java语言调用ig507金融数据库的股票API接口,以获取实时股票数据,并展示基本的编程步骤和注意事项。 步骤一:引入依赖库 在Java项目中,首先需要引入用于处理HTTP请求和网络通信的库,如Apache

Android Apk瘦身方案1——R.java文件常量内联

R.java 文件结构 R.java 是自动生成的,它包含了应用内所有资源的名称到数值的映射关系。先创建一个最简单的工程,看看 R.java 文件的内容: R文件生成的目录为app/build/generated/not_namespaced_r_class_sources/xxxxxDebug/processXXXXDebugResources/r/com/xxx/xxx/R.java

Java常用垃圾收集器

垃圾收集器 Serial 单线程,使用复制算法用于新生代的垃圾回收进行GC时必须暂停所有其他工作线程适用于内存不太大的桌面应用 Serial Old Serial的老年代版本单线程,使用标记-整理算法 ParNew Serial的多线程版本,可与CMS配合使用用于新生代的垃圾回收CPU数量多的时候才能发挥优势,适用于Server上的应用 Parallel Scavenge 目标上达

STL迭代器的基础应用

STL迭代器的应用 迭代器的定义方法: 类型作用定义方式正向迭代器正序遍历STL容器容器类名::iterator 迭代器名常量正向迭代器以只读方式正序遍历STL容器容器类名::const_iterator 迭代器名反向迭代器逆序遍历STL容器容器类名::reverse_iterator 迭代器名常量反向迭代器以只读方式逆序遍历STL容器容器类名::const_reverse_iterato

SpringCloud Hystrix初体验

文章目录 简介实验步骤bookstore应用初始化应用主程序应用配置访问应用 reading应用初始化应用主程序BookService应用配置运行应用 参考资料 简介 Hystrix是SpringCloud Netflix下的一个库,实现了Circuit Breaker(电路熔断器)模式。关于Circuit Breaker模式的原理,可以参考:Circuit Breaker(电

SpringCloud Zuul初体验

文章目录 简介Zuul服务搭建后端服务book搭建创建一个web应用主程序配置application.properties访问book服务 Zuul服务搭建创建应用添加一个pre过滤器主程序配置application.properties通过Zuul服务网关访问book服务 参考资料 简介 Zuul在SpringCloud微服务架构中扮演服务网关的角色,对外部应用访问后端服务进