首页 > 编程语言 >java基础day04:方法(函数),练习

java基础day04:方法(函数),练习

时间:2024-10-25 08:50:30浏览次数:3  
标签:java Scanner int 练习 System day04 static println public

一、Java中的方法(函数)

1.定义

方法也叫代码块,用于实现代码的封装,方便调用。主要目的是实现代码复用

2、方法和函数关系

方法和函数的关系定义
方法(面向对象)在类中定义的成员。也可以叫成员方法,属于类创建出来的对象的功能
函数(面向过程)

3、定义方法

                     权限修饰符 其他修饰符 返回值类型 方法名(参数列表){

                                                                 //方法体

                                               }

调用方法:

             通过类调用: 类.方法名(参数列表);

             通过对象调用: 对象.方法名(参数列表)

注意事项:

                1、方法运行有多个参数或无参

                2、方法定义时参数列表称为形式参数,调用时称为实际参数。

                3、方法名称+参数列表构成了方法签名

                4、方法名称使用小驼峰命名法,函数的名称一般使用下划线。

                5、在方法中可以使用return表示结束当前方法的执行,如果return之后有值,则表示结束方法并带有返回结果。

                6、如果方法没有返回值,则返回值类型应该设置为void

4、方法的重载

在同一个类中,如果出现多个方法名称,但是参数列表不同,这种方法称为方法重载。

参数列表不同指的是参数个数和类型不同。

方法的重载在多态特性中是一种编译时多态。

5、方法递归

特点:

1、自己调用自己

2、递归必须有结束条件

注意:如果方法递归过多可能会导致栈溢出的错误

StackOverflowError

6、方法的参数

方法的参数也属于局部变量

             如果参数传递的是基础数据类型,则相当于传递的是数据的副本 (值传递)

             如果是引用类型,则传递的是引用地址                                         (地址传递)

​
public class Demo1 {
    public static void main(String[] args) {
        //利用方法递归从1累加到100
        //条件:加到1就结束
        System.out.println(add(10));
      //  System.out.println(add(999)); 注意:如果方法递归过多可能会导致栈溢出的错误
        //    StackOverflowError
​
//        test();//非静态成员
    }
​
    public  void test(){
        System.out.println("Demo1");
    }
    public static void test1(){
        System.out.println("Demo1");
    }
​
    public static int test1(int b, int c){//方法重载
        return b+c;
    }
​
    public static int test1(int m, short n){//方法重载
        return m+n;
    }
​
    public static int add(int n){//方法递归
        if (n==1){
            return 1;
        }else {
          return  add(n-1)+n;
        }
​
    }
}

综合练习:

1、在控制台中打印9*9乘法表

public class Demo2Exercise {
    public static void main(String[] args) {
        //打印99
​
        for (int i = 1; i < 10; i++) {
            for (int j = 1; j <i+1; j++) {
                System.out.print(j+"*"+i+"="+(i*j)+" ");
            }
            System.out.println();
        }
​
    }
}

2、定义一个方法,判断输入的数是否为质数,是则返回true,否则返回false。

import java.util.Scanner;
​
/*、定义一个方法,判断输入的数是否为质数,是则返回true,否则返回false。
* 质数只能被一和本身整除*/
public class Demo3Exercise {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入一个大于1的数字判断是否为质数");
        int i = scanner.nextInt();
        System.out.println(judge(i));
    }
    public static boolean judge(int n){
        int index=0;
        for (int i = 1; i <=n ; i++) {
            if (n%i==0){
                index++;
            }
        }
        if (index==2||n==1){
            return true;
        }
    return false;}
}
​3、哥德巴赫猜想:任何一个大于等于6的偶数都可以分解为两个质数之和。 ​ 即:输入一个大于等于6的数,在控制台打印两个质数。结果如下:​
6 = 3 + 3 ​ 
8 = 3 + 5 ​ 
16 = 3 + 13 ​ 
16 = 5 + 11 ​ 
18 = 5 + 13 ​ 
18 = 7 + 11 ​
import java.util.Scanner;
​
/*输入一个大于等于6的数,在控制台打印两个质数。结果如下:
        6 = 3 + 3
        8 = 3 + 5
        16 = 3 + 13
        16 = 5 + 11
        18 = 5 + 13
        18 = 7 + 11*/
public class Demo4Exercise {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (true) {
            System.out.println("请输入一个大于等于6的偶数数字:");
            int i = scanner.nextInt();
            if (i < 6) {
                System.out.println("输入的数字出错,重来");
​
            }else {
                back(i);
                break;
​
            }
        }
    }
    public static void back(int num){
        for (int i = 1; i <=num ; i++) {
            if (judge(i)){//如果第一个数是质数就查看下一个
                for (int j = 1; j <=i ; j++) {
                    if (judge(j)&&(num==(i+j))){//这一步确定第二个数为质数
​
                        System.out.println(num+"="+i+"+"+j);
                    }else {
                        continue;
                    }
​
                }
​
            }else {
                continue;//当第一个数不是质数就跳出这次循环
            }
​
        }
​
    }
​
    public static boolean judge(int n){//判断质数的方法
        int index=0;
        for (int i = 1; i <=n ; i++) {
            if (n%i==0){
                index++;
            }
        }
        if (index==2){
            return true;
        }
        return false;}
}

4、判断一个3位整数是否为回文数(正数和倒数值相等),例如:121是回文数,122不是回文数。

import java.util.Scanner;
​
public class Demo5Exercise {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (true) {
            System.out.println("请输入一个三位数数字:");
            int i = scanner.nextInt();
            if (i < 100) {
                System.out.println("输入的数字出错,重来");
            } else {
                System.out.println(judge(i));
               break;
            }
        }
    }
    public static boolean judge(int num){
        int[] arr=new int[3];
        arr[0]=num/100;
        arr[1]=(num/10)-10;
        arr[2]=num%10;
        if (arr[0]==arr[2]){
            return true;
        }
   return false; }
}
​5、亲密数:如果A的所有因子之和(含1而不含本身)等于B,而且B的所有因子之和 (含1而不含本身)等于A,那么A/B称之为一对亲密数。要求:输出3000以内的所有亲密数。
/*如果整数a的所有真因数(即除了自身以外的因数)之和等于b,且整数b的所有真因数之和等于a,那么a和b就是一对亲密数。

例如,220的真因数有1、2、4、5、10、11、20、22、44、55、110,它们的和是284;而284的真因数是1、2、4、71、142,其和是220,所以220和284是一对亲密数
要求:输出3000以内的所有亲密数。*/
public class Demo6Exercise {
    public static void main(String[] args) {
        for (int i = 1; i <=3000 ; i++) {
            if (i <= 3000 && i > 0) {
                int num1 = close(i);//获取输入的数的因数和
                int num2 = close(num1);//获取输入的数的因数和 的因数和
                if (num2 == i&&i!=6&&i!=28&&i!=496) {
                    System.out.println(i + "和" + num1 + "是亲密数");
                    //     break;
                }
            } 
        }
    }
    public static int close(int num){//找到输入的数的因数和
            int index=0;
        //找到这个数的因数
        for (int i = 1; i <=num ; i++) {
            for (int j =i+1; j <=num ; j++) {
                if (num==i*j){
                  if (j==num||i==num){
                      index+=1;
                  }else {
                      index=index+i+j;
                  }
//                    System.out.println(i+"  "+j);
//                    System.out.println(index);//找到这个数的因数除去本身的和
                }
            }
        }
return index;
    }
}

6.读入一个表示年份的整数,判断这一年是否是闰年。如何判断 一个年份是否是闰年:

        1.如果这个年份能够被4 整除,且不能被100 整除,则这一年是闰年。例 如,1996 年是闰年,而相应的,1993 年就不是闰年。

         2.如果这个年份能够被100 整除,则这个数必须要能被400 整除,才是闰 年。例如,2000 年是闰年,1900 年不是闰年。

import java.util.Scanner;
​
public class Demo7Exercise {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (true) {
            System.out.println("请输入一个4位数数字:");
            int i = scanner.nextInt();
            if (!(i>=1000&&i<=9999)) {
                System.out.println("输入的数字出错,重来");
            }else {
               judge(i);
               //break;
            }
        }
    }
/*如果这个年份能够被4 整除,且不能被100 整除,则这一年是闰年。例
如,1996 年是闰年,而相应的,1993 年就不是闰年。*/
    public static  void judge(int num){
​
             if( (num%4==0&&num%100!=0)||(num%100==0&&num%400==0)){
                 System.out.println(num+"年是闰年");
             }else
             {
                 System.out.println(num+"年不是闰年");
             }
    }
}
​7.读入一个三位数,计算其各位数字之和。例如:123各位数字之和为6
import java.util.Scanner;
​
/*读入一个三位数,计算其各位数字之和。例如:123各位数字之和为6*/
public class Demo8Exercise {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (true) {
            System.out.println("请输入一个数字:");
            int i = scanner.nextInt();
            System.out.println(judge(i));
//            break;
        }
    }
    public static int judge(int num) {
        int index=0;
        while (num>0){//不知道位数循环几轮
            index=index+num%10;//先获取最后一位数
            num=num/10;
        }
        return index;
    }
}

标签:java,Scanner,int,练习,System,day04,static,println,public
From: https://blog.csdn.net/weixin_62189092/article/details/143225227

相关文章

  • 【最新原创毕设】基于JSP+SSM的民宿预约平台+79197(免费领源码)可做计算机毕业设计JAVA
    目录摘要1绪论1.1选题背景与意义1.2国内外研究现状2系统分析2.1.1技术可行性分析2.1.2 经济可行性分析2.1.3法律可行性分析2.2系统流程分析2.2.1添加信息流程2.2.2修改信息流程2.2.3删除信息流程2.3 系统功能分析2.3.1功能性分析2.3......
  • 第1关:练习-Java集合类之List的LinkedList之字符串反转
    任务要求参考答案重置记录评论12任务描述编程要求测试说明任务描述本关任务:使用LinkedList的addFirst方法实现字符串反转输出。编程要求仔细阅读右侧编辑区内给出的代码框架及注释,在Begin-End间编写程序代码,实现字符串反转输出,具体要求如下:接收给......
  • java练习
    代码importjava.util.ArrayList;importjava.util.Collection;importjava.util.Collections;importjava.util.Scanner;publicclassT08{publicstaticvoidmain(String[]args){Scannerin=newScanner(System.in);intn=in.nextInt()......
  • 刷c语言练习题12(牛客网)
    1、在上下文和头文件正常的情况下,以下代码输出的值是:12345678910111213int x = 4;void incre() {    static int x = 1;    x *= x + 1;    printf("%d", x);}int _tmain(int argc, _TCHAR *argv[]) {    int i;......
  • 每日OJ题_牛客_DP10最大子矩阵_二维前缀和_C++_Java
    目录牛客_DP10最大子矩阵_二维前缀和题目解析C++代码Java代码牛客_DP10最大子矩阵_二维前缀和最大子矩阵_牛客题霸_牛客网(nowcoder.com)描述:        已知矩阵的大小定义为矩阵中所有元素的和。给定一个矩阵,你的任务是找到最大的非空(大小至少是1*1)子矩......
  • Java锁机制
    synctronized是互斥锁吗?ChatGPTChatGPT是的,synchronized是一种互斥锁机制。在Java中,synchronized关键字用于实现同步机制,确保在多线程环境下对共享资源的访问是安全的。当一个线程进入**synchronized代码块或方法时,它会尝试获取锁。如果锁已经被其他线程持有,那么当前线程将......
  • Java 中回调机制是什么原理
    Java中回调机制的原理:1.回调机制概述;2.接口作为回调的关键;3.事件监听器模式;4.注册和解注册回调对象;5.回调与多线程;6.内置回调机制的例子。回调机制是一种常见的编程范式,特别是在事件驱动编程中。在Java中,回调机制允许一个对象(回调对象)注册在另一个对象(调用对象)上,并在特定......
  • jspm基于Java web的在线餐饮管理系统的设计和实现(11862)
     有需要的同学,源代码和配套文档领取,加文章最下方的名片哦一、项目演示项目演示视频二、资料介绍完整源代码(前后端源代码+SQL脚本)配套文档(LW+PPT+开题报告)远程调试控屏包运行三、技术介绍Java语言SSM框架SpringBoot框架Vue框架JSP页面Mysql数据库IDEA/Eclipse开发......
  • Java类和对象详解(上)
    目录前言 一.类和对象的定义1.什么是一个类?2.类的定义格式 3.一个类中应该有什么 4.什么是对象二.类的实例化1.什么是实例化?2.实例化在内存中的使用情况: 三.构造方法(构造器)1.什么是构造方法2. 默认初始化3.this关键字3.1为什么要有this关键字3.2什么是thi......
  • 日语学习《红宝书新日本语能力考试N1·N2·N3·N4·N5文字词汇(详解+练习)》PDF分享
    ​​《红宝书:新日本语能力考试文字词汇(详解+练习)》系列丛书自出版以来,广受好评,成为很多参加能力考试的学习者的必备用书。《红宝书:新日本语能力考试文字词汇(详解+练习)》按新日语能力考试指南和新真题编写,收录词汇量达6300多个:涵盖必须掌握的重点词汇3324个,涵盖重要补充词汇300......