递归方法:输入一个多位整数,计算出从0到该数1出现的个数。
package com.company.Tt;
import java.util.Scanner;
public class T4 {
public static void main(String[] args) {
Scanner cs = new Scanner(System.in);
System.out.println("请输入一个多位整数来计算出0到该数的1出现的个数......");
int n = cs.nextInt(); //要求操作者输入一个正整数
T4 t = new T4(); //声明一个T4类的对象
t.finds2(n); //调用方法2
System.out.println("0到"+n+"之间出现1的个数为:"+t.n1+"个");
//打印方法2的结果
}
public int n1 = 0; //定义一个成员变量计数器n1
public void finds2(int n2){// 方法2递归
if(n2 == 1 ){ //如果测试数为1计数器加1
this.n1 += 1;
}else{
f(n2);//检测各位的数值是否为1
finds2(n2-1); //自身调用
}
}
public void f(int a){//对多位检测是否为1
if(a>=10){//检测该数是否已经为单位数了,如果为多位数则进行求余检测
if(a%10 == 1){//检测各位
this.n1 += 1;
}
//在此减一位递归
f(a /= 10 ); //递减一位
}else {//检测该数如果为单位数是,对该单位数进行检测
if(a == 1){
this.n1 += 1;
}
}
}
}
自我感觉用for循环比较爽,这纯属娱乐一下。。。。
图解:


浙公网安备 33010602011771号