zoukankan      html  css  js  c++  java
  • Day_13【IO流】扩展案例2_统计键盘录入字符在指定项目文件中出现的次数

    分析以下需求,并用代码实现

    •  键盘录入一个字符(以字符串的形式录入)
       	判断当前字符在info3.txt当中是否存在
       		如果不存在, 给出提示
       		如果存在, 请统计出该字符出现的次数
      
       Info3.txt内容如下:
       	abcdefghijklmnopqrstuvwxyz,mnopqrstuvwxyz,mnopqrstuvwxyz,mnopqrstuvwxyz
      

    思路

    •  1.键盘录入要查找的字符
       2.创建输入流对象关联info3.txt
       3.创建StringBuilder用于存储读取到的所有字符
       4.将读取到的字符添加到StringBuilder当中
       5.调用indexOf方法判断键盘录入的字符是否存在, 如果返回-1说明不存在
       6.如果存在的话, 将StringBuilder拆分成字符数组
       7.遍历字符数组, 获取到每一个字符
       8.跟键盘录入的字符逐个进行匹配 (不要忘了将字符转换为字符串)
       9.打印出现的次数
      

    代码

    package com.itheima;
    
    import java.io.FileInputStream;
    import java.io.FileNotFoundException;
    import java.io.IOException;
    import java.util.Scanner;
    
    public class Test3 {
    	public static void main(String[] args) throws IOException {
    		//键盘录入要查找的字符
    		Scanner sc = new Scanner(System.in);
    		System.out.println("请输入要查找的字符");
    		String str = sc.nextLine();
    		
    		//创建输入流对象关联info3.txt
    		FileInputStream fis = new FileInputStream("/Users/zhaozhuang/Downloads/develop/subject/day13-IO流/homework/day13作业答案/TestDay13/info3.txt");
    		
    		//创建StringBuilder用于存储读取到的所有字符
    		StringBuilder sb = new StringBuilder();
    		
    		//将读取到的字符添加到StringBuilder当中
    		int len;
    		while((len = fis.read()) != -1) {
    			char c = (char) len;
    			sb.append(c);
    		}
    		
    		//调用indexOf方法判断键盘录入的字符是否存在, 如果返回-1说明不存在
    		if(sb.indexOf(str) != -1) {
    			//如果存在的话, 将StringBuilder拆分成字符数组
    			int count = 0;
    			char[] chs = sb.toString().toCharArray();
    			//遍历字符数组, 获取到每一个字符
    			for(char c : chs) {
    				//跟键盘录入的字符逐个进行匹配 (不要忘了将字符转换为字符串)
    				if(str.equals(c + "")) {
    					count++;
    				}
    			}
    			System.out.println(str+"一共出现了"+count+"次");
    		}
    	}
    
    }
    
    

    控制台内容
    console

  • 相关阅读:
    HDU-Digital Roots(思维+大数字符串模拟)
    CodeForces
    ZOJ-Little Sub and Pascal's Triangle(思维规律)
    CodeForces
    POJ
    CodeForces
    Codeforces Beta Round #87 (Div. 2 Only)-Party(DFS找树的深度)
    vue中的一个 Echarts 和 点击事件
    vue中echarts引入中国地图
    跨域 同源 协议 端口 域名
  • 原文地址:https://www.cnblogs.com/zzzsw0412/p/12772520.html
Copyright © 2011-2022 走看看