题目:去掉最大值、最小值后剩下的个数

华为机试—去掉最大值、最小值后剩下的个数
      输入一串数,以','分隔,输出所有数中去掉最大值、最小值之后剩下的个数。(其中最大值与最小值可能有多个)

Sample input: 3,3,5,3,6,9,7,9  

Sample output:  3

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;


public class RemoveMaxMin {
	
	public static void main(String[] args) {
		
		BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
		try {
			String str = in.readLine();
			String trim = str.trim();
			
			if(trim != null && !"".equals(trim)){
				boolean flag = isNumber(trim);
				if(flag){
					//切割字符串
					String[] s = trim.split(",");
					List<Object> list = new ArrayList<Object>();
					
					int max =  Integer.parseInt(s[0]);	//最大值
					int min = Integer.parseInt(s[0]);	//最小值
					
					for(int i = 1;i<s.length;i++){
						if(Integer.parseInt(s[i]) > max){
							max = Integer.parseInt(s[i]) ;
						}else if(Integer.parseInt(s[i]) < min){
							min = Integer.parseInt(s[i]);
						}
					}
					for(int i = 0;i<s.length;i++){
						//如果不等于最大值或者最小值则添加
						if(Integer.parseInt(s[i]) != max && Integer.parseInt(s[i]) != min){
							System.out.println(s[i]+"添加");
							list.add(s[i]);
						}else{
							System.out.println(s[i]+"不添加");
						}
					}
					System.out.println("去掉最大值、最小值之后剩下的个数:"+list.size());
				}
			}else{
				System.out.println("输入不正确请从新输入:");
			}
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
	
	/**
	 * 判断输入的是否都是数字
	 * @param str
	 * @return
	 */
	public static boolean isNumber(String str){
		String regex = "^[0-9,]*$";
		Pattern p = Pattern.compile(regex);
		Matcher m = p.matcher(str);
		if(!m.matches()){
			return false;
		}
		return true;
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,我们可以通过以下步骤来统计n的各位数字中值为d的个数num并求n中各位数字中的最小值m: 1. 首先将n转换为字符串类型,方便我们遍历n的每一位。 2. 然后使用一个循环遍历n的每一位,并将n的每一位转换为整数类型。 3. 在循环内部,如果当前位的值等于d,就将num加1。同时,如果当前位的值小于m,就将m更新为当前位的值。 4. 在循环结束后,num即为n的各位数字中值为d的个数,m即为n中各位数字中的最小值。 以下是C语言的代码示例: ``` #include <stdio.h> #include <stdlib.h> #include <string.h> int main() { // 定义变量 int n, d; int num = 0; // 值为d的个数 int m = 9; // 最小值 // 输入n和d printf("输入n和d:"); scanf("%d %d", &n, &d); // 将n转换为字符串类型 char str[16]; sprintf(str, "%d", n); // 遍历n的每一位 for (int i = 0; i < strlen(str); i++) { // 将当前位转换为整数类型 int digit = str[i] - '0'; // 如果当前位的值等于d,将num加1 if (digit == d) { num++; } // 如果当前位的值小于m,将m更新为当 ### 回答2: 题目要求在C语言中实现对一个非负整数n的各位数字进行统计,并找出最小值m。 首先,我们定义变量n和d,分别用来存储输入的非负整数和0到9之间的数字。然后,我们定义变量num用来统计n的各位数字中值为d的个数,初始值为0。最后,定义变量m用来存储n的各位数字中的最小值,初始值为INT_MAX。 接下来,我们需要对n的各位数字进行处理。我们可以使用取模运算和整除运算来逐位提取n的各位数字。 通过循环,我们不断将n对10取模,即n % 10,可以得到n的个位数字。然后,我们将得到的个位数字与d进行比较,如果相等,则将num加1。 同时,我们还需要保持m始终存储最小的数字。在每次循环中,将得到的个位数字与m进行比较,如果小于m,则将m的值更新为当前的个位数字。 当循环结束时,我们得到了n的各位数字中值为d的个数num和最小值m。 以下是使用C语言编写的代码示例: ```c #include <stdio.h> #include <limits.h> // 包含INT_MAX常量 int main() { int n, d; int num = 0; int m = INT_MAX; // 最小值初始化为INT_MAX printf("请输入一个非负整数n:"); scanf("%d", &n); printf("请输入一个0到9之间的数字d:"); scanf("%d", &d); while(n) { int digit = n % 10; if(digit == d) { num++; } if(digit < m) { m = digit; } n /= 10; } printf("n的各位数字中值为%d的个数为%d\n", d, num); printf("n的各位数字中的最小值为%d\n", m); return 0; } ``` 注意:在使用此代码时,需要在代码中处理一些异常情况,比如输入的非负整数n超出了int类型的范围,或者输入的d不是0到9之间的数字等。另外,上述代码中使用了`limits.h`头文件中的INT_MAX常量来初始化最小值m,该常量定义了int类型的最大值。 ### 回答3: 可以使用以下C语言代码实现对输入的非负整数n和0到9之间的数字d进行统计和求解最小值: ```cpp #include <stdio.h> int main() { int n, d; printf("请输入非负整数n:"); scanf("%d", &n); printf("请输入0到9之间的数字d:"); scanf("%d", &d); int num = 0; // 统计n的各位数字中值为d的个数 int m = 9; // 初始化m为最大值9,用于找到最小值 int digit; // 用于存储n的各位数字 while (n > 0) { digit = n % 10; // 获取n的个位数字 if (digit == d) { num++; // 统计值为d的个数 } if (digit < m) { m = digit; // 更新最小值m } n = n / 10; // 去除n的个位数字 } printf("n的各位数字中值为%d的个数为:%d\n", d, num); printf("n的各位数字中的最小值为:%d\n", m); return 0; } ``` 在运行程序时,会依次要求输入非负整数n和0到9之间的数字d,然后输出n的各位数字中值为d的个数num和n的各位数字中的最小值m。例如,若输入n为12345,d为3,则输出结果为num:1,m:1。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值