Java语言程序设计基础篇_编程练习题*18.17 (数组中某个指定字符出现的次数)

题目:*18.17 (数组中某个指定字符出现的次数)

编写一个递归的方法,求出数组中一个指定字符出现的次数。需要定义下面两个方法,第二个方法是一个递归的辅助方法。

java 复制代码
public static int count(char[] chars, char ch)
public static int count(char[] chars, char ch, int high)

编写一个测试程序,提示用户在一行中输入一个字符列表以及一个字符,然后显示该字符在列表中出现的次数。

代码示例

编程练习题18_17CharacterCount.java

java 复制代码
package chapter_18;

import java.util.Scanner;

public class 编程练习题18_17CharacterCount {
	public static void main(String[] args) {
		Scanner input = new Scanner(System.in);
		System.out.print("Enter a string and a character: ");
		String str = input.next();
		char ch = input.next().charAt(0);
		System.out.println(count(str.toCharArray(), ch));
		input.close();
	}
	public static int count(char[] chars,char ch) {
		return count(chars, ch,chars.length-1);
	}
	public static int count(char[] chars,char ch,int high) {
		  if (high < 0) {  
	            return 0; // 基本情况:如果high小于0,返回0  
	        }  
	        int count = 0; // 局部变量来计数,避免使用静态变量  
	        if (chars[high] == ch) {  
	            count++;  
	        }  
	        return count + count(chars, ch, high - 1); // 递归调用并累加结果  
	}

}
输出结果
java 复制代码
Enter a string and a character: AAaaAAaaAAaa a
6
相关推荐
一成码农10 小时前
JavaSE面向对象(下)
java·开发语言
Madison-No710 小时前
【C++】探秘vector的底层实现
java·c++·算法
偶尔的鼠标人10 小时前
Avalonia DataGrid 控件的LostFocus事件会多次触发
开发语言·c#
晚风残10 小时前
【C++ Primer】第十二章:动态内存管理
开发语言·c++·c++ primer
我登哥MVP11 小时前
Ajax 详解
java·前端·ajax·javaweb
十安_数学好题速析11 小时前
倍数关系:最多能选出多少个数
笔记·学习·高考
vue学习11 小时前
docker 学习dockerfile 构建 Nginx 镜像-部署 nginx 静态网
java·学习·docker
_extraordinary_11 小时前
Java Spring日志
java·开发语言·spring
PHP源码11 小时前
SpringBoot校园二手商城系统
java·spring boot·springboot二手商城·java校园二手商城系统