亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

《十萬(wàn)字Java入門練習(xí)100例》1-10例——紙上得來(lái)終覺(jué)淺,絕知此事要躬行

keithyau / 2512人閱讀

摘要:代碼實(shí)現(xiàn)在控制臺(tái)打印總結(jié)本篇文章帶大家搭好環(huán)境,并體驗(yàn)了控制臺(tái)打印。輸出結(jié)果總結(jié)熟練掌握取余和整除運(yùn)算,大有作用。終止本次循環(huán),繼續(xù)執(zhí)行下一次循環(huán)。

?本文收錄于專欄《技術(shù)專家修煉》
試用于學(xué)完「Java基礎(chǔ)語(yǔ)法」后的鞏固提高「LeetCode刷題」前的小試牛刀

作者其它優(yōu)質(zhì)專欄推薦:

?《源碼中的設(shè)計(jì)模式》——理論和實(shí)戰(zhàn)的完美結(jié)合

?《leetcode 300題》——每天一道算法題,進(jìn)大廠必備

?《從實(shí)戰(zhàn)學(xué)python》——Python的爬蟲,自動(dòng)化,AI等實(shí)戰(zhàn)應(yīng)用(代碼開源)

Java入門練習(xí)100例1-10源碼 提取碼: uqqe

文章目錄

01.控制臺(tái)打印——人生若只如初見(jiàn),環(huán)境變量配一遍

題目描述

難度:簡(jiǎn)單

在控制臺(tái)打印“Hello Java!”

知識(shí)點(diǎn)

  • 配置環(huán)境變量
  • 輸出語(yǔ)句

解題思路

1.環(huán)境搭建

“工欲善其事必先利其器”,即使輸出語(yǔ)句很簡(jiǎn)單,沒(méi)有運(yùn)行環(huán)境,也是巧婦難為無(wú)米之炊。

在線環(huán)境

有很多小伙伴和我說(shuō),還沒(méi)等體驗(yàn)Hello World的快感呢,就被配置環(huán)境變量勸退了。

一條找了在線環(huán)境供小伙伴先體驗(yàn)一下。地址

Windows配置

Windows平臺(tái)是使用者最多,配置起來(lái)最麻煩的平臺(tái),為了不被勸退,教大家最簡(jiǎn)單的方法。

1.安裝JDK

不要更改安裝位置!目錄不要有中文!

2.打開環(huán)境變量

教大家最快打開環(huán)境變量的方法:

按快捷鍵win+R后,輸入“sysdm.cpl”,然后回車,完事。

3.新建JAVA_HOME

點(diǎn)擊新增——變量名:JAVA_HOM,變量值:JDK安裝路徑。

默認(rèn)為:C:/ProgramFiles/Java/jdk1.8.0_79/bin

如此就可以,不用再配置path,class_path。

等你熟練掌握了,再研究都是什么意思即可。

Mac配置

由于Mac基于Linux內(nèi)核,安裝即可,不需要配置環(huán)境變量。

2.開發(fā)工具

開發(fā)工具比較流行的有eclipse,idea,VScode等,個(gè)人推薦idea,有關(guān)使用參考我的專欄《玩轉(zhuǎn)IDEA》

3.輸出語(yǔ)句

System.out.println("Hello Java!");是Java語(yǔ)言的輸出語(yǔ)句,相比于python的print()復(fù)雜了不少,那Java的輸出語(yǔ)句到底是怎么實(shí)現(xiàn)的?

Systemjava.long包的類,在創(chuàng)建類文件時(shí)就被加載,不需要引入。被final修飾,不能被實(shí)例化。

public final class System {  // ……}

outSystem類下的靜態(tài)變量,對(duì)應(yīng)PrintStream類,同樣的還有in,err變量。

public final static PrintStream out = null;

printlnPrintStream類的方法,就是在這里實(shí)現(xiàn)IO流的輸出。

    public void println(Object x) {        String s = String.valueOf(x);        synchronized (this) {            print(s);            newLine();        }    }

代碼實(shí)現(xiàn)

/** * https://www.nhooo.com/tool/java/ * 在控制臺(tái)打印"hello java" */public class question_01 {    public static void main(String[] args) {        System.out.println("hello java");    }}

總結(jié)

本篇文章帶大家搭好環(huán)境,并體驗(yàn)了控制臺(tái)打印。

下一題控制臺(tái)輸入,大家可以先思考一下?

加入組隊(duì)刷題


02.鍵盤輸入——三種方式

題目描述

難度:簡(jiǎn)單

從鍵盤輸入一個(gè)數(shù)字,打印出該數(shù)字的絕對(duì)值。

知識(shí)點(diǎn)

  • 鍵盤輸入
  • 數(shù)學(xué)運(yùn)算函數(shù)
  • 類型轉(zhuǎn)換

解題思路

1.鍵盤輸入

和打印一樣,相比于python的input(),Java的輸入也比較麻煩,但是作為初學(xué)者練習(xí),屬于必會(huì)內(nèi)容。

下面一條會(huì)介紹三種輸入的方法,小伙伴們要注意他們的區(qū)別。

  • System.in

    該方法能獲取從鍵盤輸入的字符,但只能針對(duì)一個(gè)字符的獲取,獲取的只是char類型的。如果想獲得int,float等類型的輸入,比較麻煩。具體見(jiàn)代碼。

  • InputStreamReader

    可以獲取鍵盤輸入的字符串,如果要獲取的是int,float等類型的仍然需要轉(zhuǎn)換。具體見(jiàn)代碼。

  • Scanner

    可以獲取鍵盤輸入的字符串,有現(xiàn)成的獲取int,float等類型數(shù)據(jù),非常方便,被廣泛使用。具體見(jiàn)代碼。

2.數(shù)學(xué)運(yùn)算函數(shù)

Java 的 Math類包含了用于執(zhí)行基本數(shù)學(xué)運(yùn)算的屬性和方法,如初等指數(shù)、對(duì)數(shù)、平方根和三角函數(shù)。

Math 的方法都被定義為static形式,通過(guò)Math類可以在主函數(shù)中直接調(diào)用。

下面簡(jiǎn)單介紹幾個(gè)常用的函數(shù)。具體見(jiàn)代碼。

  • abs() 返回參數(shù)的絕對(duì)值。
  • min()返回兩個(gè)參數(shù)中的最小值。
  • max()返回兩個(gè)參數(shù)中的最大值。
  • pow()返回第一個(gè)參數(shù)的第二個(gè)參數(shù)次方。
  • sqrt()求參數(shù)的算術(shù)平方根。
  • random()返回一個(gè)隨機(jī)數(shù)。
  • Math.PI圓周率

3.類型轉(zhuǎn)換

Java支持顯示和隱式轉(zhuǎn)換,在實(shí)際應(yīng)用中要善于使用包裝類的parseXXX()valueOf()方法。

特別的,char轉(zhuǎn)int可以通過(guò)ascii的方式。例:

char ch = "9";int i=ch-"0"System.out.println(i);

代碼實(shí)現(xiàn)

三種方法實(shí)現(xiàn)。

import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;import java.util.Scanner;/** * 從鍵盤輸入一個(gè)數(shù)字,打印出該數(shù)字的絕對(duì)值。 */public class question_02 {    public static void main(String[] args) throws IOException {        question_02 question02 = new question_02();        question02.method1();//        question02.method2();//        question02.method3();    }    //System.in    public void method1() throws IOException {        System.out.println("Please Enter Data:");        char i = (char)System.in.read();        System.out.println("System.in --> "+Math.abs(i-"0"));    }    //InputStreamReader    public void method2() throws IOException {        System.out.println("Please Enter Data:");        //new一個(gè)InputStreamReader對(duì)象        InputStreamReader is = new InputStreamReader(System.in);        //BufferedReader的有參構(gòu)造的方法        BufferedReader br = new BufferedReader(is);        //讀取一行,拋出異常        String line = br.readLine();        System.out.println("InputStreamReader --> "+Math.abs(Integer.parseInt(line)));    }    //Scanner    public void method3(){        System.out.println("Please Enter Data:");        Scanner sc = new Scanner(System.in);        //讀取int        int i = sc.nextInt();        //String s = sc.nextLine();  讀取字符串型輸入        //float f = sc.nextFloat();  讀取float型輸入        System.out.println("Scanner --> "+Math.abs(i));    }}

輸出結(jié)果

擴(kuò)展總結(jié)

思考:sc.next()sc.nextLine()有什么區(qū)別?

答:next()遇到空格停止接收。


03.短路與和邏輯與的區(qū)別——老實(shí)人和機(jī)靈鬼

題目描述

難度:簡(jiǎn)單

/*** 短路與和邏輯與*/public class question_03 {   public static void main(String[] args){       int i=5;       boolean e = i > 6 & i++ > 7;       System.out.println(e);       System.out.println(i);       e = i > 6 && i++ > 7;       System.out.println(e);       System.out.println(i);   }}

請(qǐng)寫出以上代碼的輸出

知識(shí)點(diǎn)

  • 關(guān)系運(yùn)算符
  • 自增運(yùn)算

解題思路

  • 邏輯與(&)和短路與(&&)在運(yùn)算上對(duì)條件的結(jié)果判斷不會(huì)產(chǎn)生影響,但會(huì)對(duì)條件本身的運(yùn)算有影響。

  • 邏輯與(&)在運(yùn)算時(shí)會(huì)連續(xù)運(yùn)算所有需要判斷的命令.但短路與當(dāng)遇到false時(shí)就停止運(yùn)算。

代碼實(shí)現(xiàn)

分析

第一次判斷是邏輯與,老實(shí)人不管對(duì)錯(cuò),全部計(jì)算一下,則i++被執(zhí)行,輸出e=false;i=6

第二次判斷是短路與,機(jī)靈鬼先判斷第一個(gè)是錯(cuò)的,就不再往下計(jì)算,i++不被執(zhí)行,輸出e=false;i=6;

驗(yàn)證

總結(jié)

在實(shí)際開發(fā)中為了增強(qiáng)代碼的可讀性,統(tǒng)一使用短路與,且不在判斷條件中做任何運(yùn)算。


04.三數(shù)排序——兩數(shù)交換高級(jí)算法

題目描述

難度:簡(jiǎn)單

用if語(yǔ)句實(shí)現(xiàn)a、b、c的值按從小到大排序

知識(shí)點(diǎn)

  • if判斷
  • 兩數(shù)交換

解題思路

1.if判斷

本題整理的思路就是比較 - > 交換

if作為一種分支結(jié)構(gòu),用來(lái)根據(jù)判斷條件的不同做不同的后續(xù)處理。

2.兩數(shù)交換

通常的做法,好比交換兩個(gè)杯子的水,需要先找來(lái)一個(gè)空杯子,也就是一個(gè)臨時(shí)變量存值。代碼如下:

int t=a;a=b; b=t;

高級(jí)做法,不使用其他變量如何做?思考?一下,文末給出答案。

代碼實(shí)現(xiàn)

/** * 用if語(yǔ)句實(shí)現(xiàn)a、b、c的值按從小到大排序 */public class question_04 {    public static void main(String args[]){        int a=9,b=5,c=7,t;        if(a>b) {            t=a; a=b; b=t;        }        if(a>c) {            t=a; a=c; c=t;        }        if(b>c) {            t=b; b=c; c=t;        }        System.out.println("a="+a+",b="+b+",c="+c);    }}

輸出結(jié)果

總結(jié)

如何不用其他變量交換兩個(gè)數(shù)的值?

答,將兩個(gè)數(shù)做加/乘法。在做減/除法。代碼如下:

a=a*b;b=a/b; //等價(jià)于 a*b/b=a,即將a的值賦給了ba=a/b; //等價(jià)于 a*b/a=b,即將b的值賦給了a

加減的方式留給大家去實(shí)現(xiàn)。


05.計(jì)算 5+ 55 + 555 + … 的前10項(xiàng)的和——for循環(huán)

題目描述

難度:簡(jiǎn)單

計(jì)算 5+ 55 + 555 + … 的前10項(xiàng)的和

知識(shí)點(diǎn)

  • for循環(huán)
  • 簡(jiǎn)單數(shù)學(xué)

解題思路

1.for循環(huán)

簡(jiǎn)單的for循環(huán)的應(yīng)用,確定好初始值,步長(zhǎng),終止值即可。

2.找規(guī)律

難點(diǎn)在如何確定加數(shù),即找到加數(shù)之間的規(guī)律。

不難發(fā)現(xiàn)每一個(gè)加數(shù)是前一個(gè)加數(shù)的10倍+5。

??注意一點(diǎn):最終的結(jié)果可能會(huì)超出int的范圍,需要使用long。

代碼實(shí)現(xiàn)

/** *計(jì)算 5+ 55 + 555 + ... 的前10項(xiàng)的和 */public class question_05 {    public static void main(String args[]){        //定義變量        long sum=0,a=5,item=a;        //初值1,步長(zhǎng)1,終值10        for(int i=1;i<=10;i++) {            //追加到總和            sum=sum+item;          	//確定下一個(gè)加數(shù)            item=item*10+a;        }        System.out.println(sum);    }}

輸出結(jié)果

總結(jié)

除了for循環(huán),用while能否實(shí)現(xiàn)呢?什么時(shí)候用for?什么時(shí)候用while?


06.計(jì)算 1 + 1/2! + 1/3! + 1/4! + … + 1/20! 的值——初窺動(dòng)態(tài)規(guī)劃

題目描述

難度:簡(jiǎn)單

計(jì)算 1 + 1/2! + 1/3! + 1/4! + … + 1/20! 的值。

知識(shí)點(diǎn)

  • 循環(huán)結(jié)構(gòu)
  • 階乘的計(jì)算
  • 初窺動(dòng)態(tài)規(guī)劃

解題思路

1.循環(huán)結(jié)構(gòu)

觀察算式的規(guī)律,從1-20,每次加1,循環(huán)20次。

2.階乘的計(jì)算

n!是為階乘,等于1*2*3*4...(n-1)*n

3.初窺動(dòng)態(tài)規(guī)劃

動(dòng)態(tài)規(guī)劃,一直是算法中的難點(diǎn),本次不做深度講解,通俗的說(shuō)一下。

就是把復(fù)雜問(wèn)題簡(jiǎn)單化,比如4 的階乘可以看到3 的階乘再乘4,而3的階乘可以看做2的階乘再乘3,2的階乘等于1乘2。

其實(shí)就是這樣一個(gè)思想,可以看下leetcode《爬樓梯》這道題。

代碼實(shí)現(xiàn)

/** * 計(jì)算 1 + 1/2! + 1/3! + 1/4! +  + 1/20! 的值 */public class question_06 {    public static void main(String args[]) {        double sum=0,a=1;        int i=1;        while(i<=20) {            sum=sum+a;            i=i+1;            //關(guān)鍵點(diǎn),動(dòng)態(tài)規(guī)劃思想            a=a*(1.0/i);        }        System.out.println("sum="+sum);    }}

輸出結(jié)果

總結(jié)

上一節(jié)的問(wèn)題:什么時(shí)候用for?什么時(shí)候用while?

答:其實(shí)兩者區(qū)別不大,大多數(shù)情況都可以解決問(wèn)題。只需記住一點(diǎn):循環(huán)次數(shù)未知時(shí)用while


07.各數(shù)字的和——取余運(yùn)算

題目描述

難度:簡(jiǎn)單

計(jì)算給定整數(shù)12345的各位上數(shù)字的和。

知識(shí)點(diǎn)

  • 除法運(yùn)算
  • 取余運(yùn)算

解題思路

解題的關(guān)鍵在于如何拿到各個(gè)位上的數(shù)字。

舉例:拿到34的個(gè)位和十位

int a=34;//整除運(yùn)算,拿到3int b=34/10;//返回余數(shù)4int c=34%10;

代碼實(shí)現(xiàn)

/** * 計(jì)算給定整數(shù)12345的各數(shù)字的和。 */public class question_07 {    public static void main(String args[]) {        int y = 12345;        int r = 0 ;        int sum = 0;        while(y!=0) {            r = y % 10;            sum += r;            y = y / 10;        }        System.out.println("y = " + sum);    }}

輸出結(jié)果

總結(jié)

熟練掌握取余和整除運(yùn)算,大有作用。


08.素?cái)?shù)和——break和continue

題目描述

難度:簡(jiǎn)單

計(jì)算500以內(nèi)的素?cái)?shù)和。

知識(shí)點(diǎn)

  • 素?cái)?shù)的定義
  • breakcontinue
  • 開方運(yùn)算

解題思路

1.素?cái)?shù)的定義

大于1的自然數(shù)中,除了1和它本身以外不再有其他因數(shù)就叫做素?cái)?shù)。

比如2=1×2;5=1×5;所以2、5就是素?cái)?shù)。但6=1×6=2×3,即6除了1和自身6外還有其他因數(shù)2和3,不是素?cái)?shù)。

2.break和continue

break:終止所有循環(huán),直接跳出。

continue:終止本次循環(huán),繼續(xù)執(zhí)行下一次循環(huán)。

3.開方運(yùn)算

Math.sqrt()

代碼實(shí)現(xiàn)

/** * 求500以內(nèi)的素?cái)?shù)和 */public class question_08 {    public static void main(String[] args) {        int sum=0,i,j;        for(j=2;j<=500;j++) {               for( i=2;i<=j/2;i++) {                if(j%i==0)                    break; //說(shuō)明除去1和本身有其他除數(shù),不是素?cái)?shù),也就沒(méi)有繼續(xù)循環(huán)的必要            }            if(i>j/2) {   //i>j/2說(shuō)明,break沒(méi)有被執(zhí)行到,即除去1和本身無(wú)其他除數(shù),是素?cái)?shù)                sum+=j;            }        }        System.out.println(sum);    }}

輸出結(jié)果

擴(kuò)展總結(jié)

思考:如果是計(jì)算500w以內(nèi)的素?cái)?shù)和,如何提高效率呢?

回答:將j/2改為Math.sqrt()。


09.數(shù)組中的最小值——一維數(shù)組

題目描述

難度:簡(jiǎn)單

輸出一維整型數(shù)組中的值最小的那個(gè)元素及其下標(biāo)。

知識(shí)點(diǎn)

  • 一維數(shù)組
  • 排序

解題思路

1.什么是數(shù)組

所謂的數(shù)組指的就是一組相關(guān)類型的變量集合,并且這些變量可以按照統(tǒng)一的方式進(jìn)行操作。

定義數(shù)組

int data[] = new int[3];// 數(shù)組的長(zhǎng)度為3,超過(guò)會(huì)報(bào)下標(biāo)越界異常,且下標(biāo)從0開始

添加元素

data[0] = 10; // 第一個(gè)元素data[1] = 20; // 第二個(gè)元素data[2] = 30; // 第三個(gè)元素

循環(huán)打印

for(int x = 0; x < data.length; x++) {			System.out.println(data[x]); //通過(guò)循環(huán)控制索引}

2.排序算法

其實(shí)嚴(yán)格來(lái)說(shuō)我們并沒(méi)有用到排序算法,但有一些思想在里面,想提前了解可以看這篇。

冒泡排序

代碼實(shí)現(xiàn)

/** * 輸出一維整型數(shù)組中的值最小的那個(gè)元素及其下標(biāo)。 */public class question_09 {    public static void main(String args[]) {        int a[] = { 12, 24, 6, 37, 3, 22, 64 };        int min = 0;        for (int i = 1; i < a.length; i++) {            if (a[min] > a[i]) {                min = i;            }        }        System.out.println("a[" + min + "] = " + a[min]);    }}

輸出結(jié)果

擴(kuò)展總結(jié)

本節(jié)練習(xí)了一維數(shù)組的操作,下一節(jié)練習(xí)二維數(shù)組。


10.各行元素之和——二維數(shù)組

題目描述

難度:簡(jiǎn)單

計(jì)算二維數(shù)組中各行元素之和并查找其值最大的那個(gè)行。

知識(shí)點(diǎn)

  • 二維數(shù)組
  • 雙重循環(huán)

解題思路

1.二維數(shù)組

二維數(shù)組本質(zhì)上是以數(shù)組作為數(shù)組元素的數(shù)組,即“數(shù)組的數(shù)組”??梢韵胂癯梢粋€(gè)方陣。

定義數(shù)組

int brr [] []=new int[][3]; //二維數(shù)組中行可以省略,至少寫出列

添加元素

brr[0][0]=1; //下標(biāo)同樣從0開始,可以指定位置賦值,也可以整體賦值。brr={  {1,2,3},  {5,6,7},  {9,10,11}};

循環(huán)遍歷

//遍歷行for(int i=0;i<3;i++){  	 //遍歷列     for(int j=0;j<3;j++){       
            
                     
             
               

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/122020.html

相關(guān)文章

  • JustDoIt:立刻開始你的編程之旅

    摘要:于是乎,我建立了這個(gè)項(xiàng)目,收錄一些有趣的小程序,便于閱讀和思考。下面是一些列舉一些有趣的內(nèi)容這是來(lái)自編程從入門到實(shí)踐中的一個(gè)小游戲。用語(yǔ)言實(shí)現(xiàn)的編譯器。做的小博客,持續(xù)開發(fā)中這個(gè)項(xiàng)目還在不斷豐富中,如果你有什么有趣的分享,歡迎聯(lián)系我。 紙上得來(lái)終覺(jué)淺,絕知此事要躬行。 這本書或這個(gè)視頻看完了,我可以做點(diǎn)什么?編程難道只是命令行打印些東西?該找點(diǎn)什么適合練手的項(xiàng)目來(lái)練習(xí)練習(xí)呢? 我想可能...

    arashicage 評(píng)論0 收藏0
  • 夯實(shí)JS基礎(chǔ)(一):this的指向問(wèn)題和經(jīng)典面試題

    摘要:很多高級(jí)編程語(yǔ)言都給新創(chuàng)建的對(duì)象分配一個(gè)引用自身的指針比如中的指針,中的,也有指針,雖然它的指向可能相對(duì)復(fù)雜些,但是指向的,永遠(yuǎn)只可能是對(duì)象。 很多高級(jí)編程語(yǔ)言都給新創(chuàng)建的對(duì)象分配一個(gè)引用自身的指針,比如JAVA、C++中的this指針,python中的self,JavaScript也有this指針,雖然它的指向可能相對(duì)復(fù)雜些,但是this指向的,永遠(yuǎn)只可能是對(duì)象。 一、在一般函數(shù)方法...

    EasonTyler 評(píng)論0 收藏0
  • 夯實(shí)JS基礎(chǔ)(一):this的指向問(wèn)題和經(jīng)典面試題

    摘要:很多高級(jí)編程語(yǔ)言都給新創(chuàng)建的對(duì)象分配一個(gè)引用自身的指針比如中的指針,中的,也有指針,雖然它的指向可能相對(duì)復(fù)雜些,但是指向的,永遠(yuǎn)只可能是對(duì)象。 很多高級(jí)編程語(yǔ)言都給新創(chuàng)建的對(duì)象分配一個(gè)引用自身的指針,比如JAVA、C++中的this指針,python中的self,JavaScript也有this指針,雖然它的指向可能相對(duì)復(fù)雜些,但是this指向的,永遠(yuǎn)只可能是對(duì)象。 一、在一般函數(shù)方法...

    lucas 評(píng)論0 收藏0
  • 入口文件開始,分析Vue源碼實(shí)現(xiàn)

    摘要:一方面是因?yàn)橄胍朔约旱亩栊?,另一方面也是想重新溫故一遍。一共分成了個(gè)基礎(chǔ)部分,后續(xù)還會(huì)繼續(xù)記錄。文章中如果有筆誤或者不正確的解釋,也歡迎批評(píng)指正,共同進(jìn)步。最后地址部分源碼 Why? 網(wǎng)上現(xiàn)有的Vue源碼解析文章一搜一大批,但是為什么我還要去做這樣的事情呢?因?yàn)橛X(jué)得紙上得來(lái)終覺(jué)淺,絕知此事要躬行。 然后平時(shí)的項(xiàng)目也主要是Vue,在使用Vue的過(guò)程中,也對(duì)其一些約定產(chǎn)生了一些疑問(wèn),可...

    Karrdy 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<