在程序中引入一个名为readInteger的新方法,方法头为: o私有静态int readInteger() •它不接收任何参数,并且应该返回用户键入的下一个可用整数,邀请它们 重复输入一个整数,直到完成为止。您可以通过复制 从主方法的主体开始,进行少量编辑。注意:该方法不应显示有效的整数 一旦它被接收并且不需要对无效输入进行计数,它应该只返回整数。 •现在使用for循环输入十个语句来替换主方法主体中的语句 整数(在循环体中使用一个调用readInteger的语句),将它们相加 并且在输入处理完成之后显示它们的平均值。

时间: 2023-02-24 11:47:14 浏览: 63
以下是程序代码: ``` private static int readInteger() { Scanner sc = new Scanner(System.in); while (!sc.hasNextInt()) { sc.next(); System.out.println("Invalid input. Please enter an integer."); } return sc.nextInt(); } public static void main(String[] args) { int sum = 0; for (int i = 0; i < 10; i++) { int num = readInteger(); sum += num; } System.out.println("The average of the ten numbers is: " + sum / 10); } ``` 这段代码创建了一个名为`readInteger`的方法,它用于读取用户输入的整数。当用户输入无效数据时,它会提示用户重新输入。然后在主方法中,使用一个for循环调用`readInteger`方法十次,并将输入的十个数相加,最后显示它们的平均值。
相关问题

用java写一段词法分析的程序

以下是一个简单的 Java 词法分析器示例,它可以将输入的字符串分解为标记或词法单元: ```java import java.util.ArrayList; public class Lexer { private String input; private ArrayList<Token> tokens; private int position; public Lexer(String input) { this.input = input; this.tokens = new ArrayList<Token>(); this.position = 0; } public ArrayList<Token> tokenize() throws Exception { while (position < input.length()) { char currentChar = input.charAt(position); if (Character.isDigit(currentChar)) { tokens.add(new Token(TokenType.INTEGER, readInteger())); } else if (Character.isLetter(currentChar)) { tokens.add(new Token(TokenType.IDENTIFIER, readIdentifier())); } else if (currentChar == '+') { tokens.add(new Token(TokenType.PLUS, "+")); position++; } else if (currentChar == '-') { tokens.add(new Token(TokenType.MINUS, "-")); position++; } else if (currentChar == '*') { tokens.add(new Token(TokenType.MULTIPLY, "*")); position++; } else if (currentChar == '/') { tokens.add(new Token(TokenType.DIVIDE, "/")); position++; } else if (currentChar == '(') { tokens.add(new Token(TokenType.LPAREN, "(")); position++; } else if (currentChar == ')') { tokens.add(new Token(TokenType.RPAREN, ")")); position++; } else if (currentChar == '=') { tokens.add(new Token(TokenType.ASSIGNMENT, "=")); position++; } else if (currentChar == ';') { tokens.add(new Token(TokenType.SEMICOLON, ";")); position++; } else if (currentChar == ' ') { position++; } else { throw new Exception("Invalid character: " + currentChar); } } return tokens; } private String readInteger() { String result = ""; while (position < input.length() && Character.isDigit(input.charAt(position))) { result += input.charAt(position); position++; } return result; } private String readIdentifier() { String result = ""; while (position < input.length() && Character.isLetterOrDigit(input.charAt(position))) { result += input.charAt(position); position++; } return result; } } ``` 上述代码中,我们定义了 `Lexer` 类,它接受一个字符串作为输入,并将其分解为标记或词法单元。我们使用 `TokenType` 枚举类来表示不同类型的标记,例如整数、标识符、加号、减号等。 在 `tokenize()` 方法中,我们使用一个循环来遍历输入字符串中的每个字符。根据当前字符的类型,我们使用不同的方法来读取标记。例如,如果当前字符是数字,则我们使用 `readInteger()` 方法来读取整数标记。如果当前字符是字母,则我们使用 `readIdentifier()` 方法来读取标识符标记。如果当前字符是运算符或括号,则我们直接将其添加到标记列表中。 在 `readInteger()` 和 `readIdentifier()` 方法中,我们使用另一个循环来读取连续的数字或字母字符,直到遇到非数字或字母字符为止。 最后,我们返回一个标记列表,其中包含输入字符串中的所有标记或词法单元。如果输入字符串中包含无法识别的字符,则我们抛出一个异常。

用java写一个词法分析器

好的,我可以为你提供一个基于 Java 的简单词法分析器实现。你可以参考以下代码: ```java public class Lexer { private String input; private int currentPosition; public Lexer(String input) { this.input = input; this.currentPosition = 0; } public Token getNextToken() { while (currentPosition < input.length()) { char currentChar = input.charAt(currentPosition); if (Character.isDigit(currentChar)) { return new Token(TokenType.INTEGER, readInteger()); } if (Character.isLetter(currentChar)) { return new Token(TokenType.IDENTIFIER, readIdentifier()); } if (currentChar == '+') { currentPosition++; return new Token(TokenType.PLUS, "+"); } if (currentChar == '-') { currentPosition++; return new Token(TokenType.MINUS, "-"); } if (currentChar == '*') { currentPosition++; return new Token(TokenType.MULTIPLY, "*"); } if (currentChar == '/') { currentPosition++; return new Token(TokenType.DIVIDE, "/"); } if (currentChar == '(') { currentPosition++; return new Token(TokenType.LEFT_PAREN, "("); } if (currentChar == ')') { currentPosition++; return new Token(TokenType.RIGHT_PAREN, ")"); } if (currentChar == '=') { currentPosition++; return new Token(TokenType.EQUALS, "="); } if (currentChar == ';') { currentPosition++; return new Token(TokenType.SEMICOLON, ";"); } if (Character.isWhitespace(currentChar)) { skipWhitespace(); continue; } throw new RuntimeException("Invalid token: " + currentChar); } return new Token(TokenType.EOF, ""); } private String readInteger() { StringBuilder sb = new StringBuilder(); while (currentPosition < input.length() && Character.isDigit(input.charAt(currentPosition))) { sb.append(input.charAt(currentPosition)); currentPosition++; } return sb.toString(); } private String readIdentifier() { StringBuilder sb = new StringBuilder(); while (currentPosition < input.length() && Character.isLetterOrDigit(input.charAt(currentPosition))) { sb.append(input.charAt(currentPosition)); currentPosition++; } return sb.toString(); } private void skipWhitespace() { while (currentPosition < input.length() && Character.isWhitespace(input.charAt(currentPosition))) { currentPosition++; } } } ``` 这是一个简单的词法分析器,它可以识别整数、标识符、运算符等。你可以根据需要修改或扩展它以适应你的具体需求。

相关推荐

docx

最新推荐

recommend-type

2024嵌入式大厂面经CVTE

2024嵌入式大厂面经CVTE提取方式是百度网盘分享地址
recommend-type

掺工业废钛石膏制备自密实混凝土研究

虽然自密实混凝土作为目前建筑领域应用最广泛的材料,但是由于其性能等方面的局限性,导致了目前普通自密实混凝土难以满足不断提高的工程建设要求。研究发现, 通过在自密实混凝土中添加钛石膏等可以验证混凝土各方面性能的提高。且向自密实混凝土中添加工业废钛石膏,将其应用于建材领域,不仅可以解决目前市场上对自密实混凝土的运用问题,还能改善环境及固体废弃物综合利用的问题。因此开展对掺工业废钛石膏制备自密实混凝土的研究。 在本文中,我们对掺工业废钛石膏制备自密实混凝土静力学性能做了系统性试验,对于掺工业废钛石膏制备自密实混凝土中钛石膏质量份数,我们采用的是 85 份、90 份和 95 份。整个试验可分为两个部分:一、单轴压缩试验和巴西圆盘劈裂抗拉试验,通过这两个试验主要得出钛石膏自密实混凝土的抗压强度、弹性模量与劈裂抗拉强度;二、不同粉料配比对掺工业废钛石膏制备自密实混凝土的影响,通过对不同粉料制成的掺工业废钛石膏制备自密实混凝土的坍落扩展度和离析率影响试验。最后分析试验数据,从而得出本文结论。 本文通过对大量试验数据的总结与分析,结合国内外相关研究的已有结论, 总结出当工业废钛石膏质量份数增加到
recommend-type

2024年家庭农场市场趋势分析.pptx

行业报告
recommend-type

DirectShow过滤器-AAC编码器

本过滤器将PCM音频流编码为AAC音频流,由输出引脚输出。 参见介绍文章:https://blog.csdn.net/h3974/article/details/139550603?csdn_share_tail=%7B%22type%22%3A%22blog%22%2C%22rType%22%3A%22article%22%2C%22rId%22%3A%22139550603%22%2C%22source%22%3A%22h3974%22%7D 过滤器名称:AAC编码器 过滤器GUID:{59FB3C29-4C37-47D9-AA73-1DFEDC0DDF71} 过滤器有1个输入引脚和1个输出引脚。 输入引脚 标识:In 媒体类型: 主要类型:MEDIATYPE_Audio 子类型:MEDIASUBTYPE_PCM 格式类型:FORMAT_WaveFormatEx 输出引脚 标识:Out 媒体类型: 主要类型:MEDIATYPE_Audio 子类型:MEDIASUBTYPE_MPEG_HEAAC 格式类型:FORMAT_WaveFormatEx
recommend-type

电商平台用户行为分析与可视化数据集.zip

电商平台用户行为分析与可视化数据集
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB正态分布协方差分析:揭示正态分布变量之间的协方差

![MATLAB正态分布协方差分析:揭示正态分布变量之间的协方差](https://site.cdn.mengte.online/official/2021/11/20211128213137293.png) # 1. 正态分布概述 正态分布,又称高斯分布,是统计学中最重要的连续概率分布之一。它广泛应用于自然科学、社会科学和工程领域。 正态分布的概率密度函数为: ``` f(x) = (1 / (σ√(2π))) * exp(-(x - μ)² / (2σ²)) ``` 其中: - μ:正态分布的均值 - σ:正态分布的标准差 - π:圆周率 正态分布具有以下特性: - 对称性:
recommend-type

我正在开发一款个人碳足迹计算app,如何撰写其需求分析文档,请给我一个范例

为了更全面、清晰地定义个人碳足迹计算app的需求,需求分析文档应该包含以下内容: 1.项目简介:对该app项目的概述及目标进行说明。 2.用户分析:包括目标用户群、用户需求、行为等。 3.功能需求:对app的基本功能进行定义,如用户登录、数据录入、数据统计等。 4.非功能需求:对使用app的性能和质量等进行定义,如界面设计、数据安全、可扩展性等。 5.运行环境:包括app的开发环境和使用环境。 下面是一个范例: 需求分析文档 1. 项目简介 该app项目旨在为用户提供一款方便、易用、可定制的个人碳足迹计算平台,以促进环保和可持续性发展。 2. 用户分析 目标用户群:全球关
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。