猿圈网的几个 Java 挑战题评测题分享

本贴最后更新于 2277 天前,其中的信息可能已经时移世异

先不管猿圈网是干什么的,反正我觉得那是一个可以做题,可以敲代码的网站 😆 ,昨天意外发现了这个网站,在上面做了几道 Java 的题,总感觉哪里做的不太对劲,分享出来相互交流一下,帮忙看看我做的到底哪块是不对的。

相关说明:

代码中从注释 //No.1 开始到注释 //end_code 结束是需要自己写代码实现功能的地方,除此部分之外的代码基本都是试题给定的代码。

1. 插入排序

用 java 代码实现插入排序

import java.util.Arrays; // 自己导入

public class InsertSortTest {

	public static void main(String[] args) {
		int[] array = { 49, 38, 65, 97, 76, 13, 27, 14, 10 };
		//No.1
		//开始写代码,用java实现插入排序
		if (array == null || array.length == 0) {	//判断数组不存在或为空
			return;
		}
		 
		int i, j, tmp;
		int len = array.length;
		for (i = 1; i < len; i++) { // 从 1 开始遍历 array
			j = i;
			tmp = array[i];
			while (j > 0 && tmp < array[j - 1]) { // 如果 array[i] < array[i - 1]
				array[j] = array[j - 1]; // array[i] = array[i - 1]
				j--;
			}
			array[j] = tmp; // array[i - 1] = array[i]
		}
		System.out.println(Arrays.toString(array));
		//end_code
	}
}

### 2. ip 转化为整数
> #### `使用 java 代码实现将 IPV4 的 IP 地址转化为对应整数并输出,比如 192.168.199.1 对应整数为 3232286465`
> 
> ``` java
> public class IpToNumber {
> 	public static void main(String[] args) {
> 		IpToNumber ipToNumber = new IpToNumber();
> 		System.out.println("IPV4的IP地址对应的整数为 : " + ipToNumber.ipToLong("192.168.199.1"));
> 	}
> 
> 	public long ipToLong(String ipAddress) {
> 		long result = 0;
> 		String[] ipAddressInArray;
> 		
> 		//No.1
> 		//开始写代码,将IPV4的IP地址转化为相对应的整数
> 		ipAddressInArray = ipAddress.split("\\."); // 将 ip 截为 4 个部分字符串
> 		long[] ipLong = new long[4];
> 		for (int i = 0; i < ipAddressInArray.length; i++) {
> 			ipLong[i] = Long.parseLong(ipAddressInArray[i]); // 分别转为 long 型后存入 ipLong 中
> 		}
> 		result = (ipLong[0] << 24) + (ipLong[1] << 16) + (ipLong[2] << 8) + ipLong[3]; // 进行位移操作
> 		//end_code
> 		return result;
> 	}
> }
> ```

### 3. 找重复数字和未出现数字
> #### `假设 0-10000 数字中有 2 个数字相同,还有 1 个数字没有出现,仅遍历一次数组找出重复数和未出现的数字。`
> 
> ``` java
> public class FindNumberTest {
> 	public static void main(String[] args) {
> 		int number[] = new int[10001];
> 		int numCopy[] = new int[10001]; // 这个变量我没有用到...不知道是用来干嘛的
> 		int repeat = 0, notAppear = 0;
> 		int sumNumber = 0;
> 		int i;
> 
> 		for (i = 0; i < 10001; i++) {//数组初始化
> 			number[i] = i;
> 		}
> 		number[573] = 5236;//设定重复数字5236出现两次,573不出现
> 
> 		//No.1
> 		//开始写代码,仅遍历一次数组找出重复数和未出现的数字。 
> 		for (int j = 0; j < number.length; j++) {
> 			if(j != number[j] && number[j] == number[sumNumber]) {  // 因为数组 number[0] = 0, number[1] = 1... 所以这算不算是投机取巧 :joy: 
> 			  repeat = number[j];
> 			  notAppear = j;
> 			}
> 			sumNumber++;
> 		}		
> 		//end_code
> 		System.out.println("重复数字:"+repeat + " 未出现数字:" + notAppear);
> 	}
> }
> ```

### 4. 约瑟夫环问题
> #### `用 java 代码实现约瑟夫环问题,50 个人围成一圈报数,报到 3 的倍数的离开,求最后剩下的那个人原来站的位置`
> ``` java
> // 在主方法中调用
> public static void YueSeFuLoop() { 
> 	LinkedList linkedlist = new LinkedList();
> 	//No.1
> 	//开始写代码,有50人围成一圈报数,报到3的倍数的人离开,求最后剩下的人原来站在第几位,实现removeFromList方法
> 	for (int i = 1; i <= 50; i++) {  
> 		linkedlist.add(i);  
> 	}  
> 	int index = 0;
> 	while(linkedlist.size() > 0) { // 最后一个人离开之前
> 		for (int i = 0; i < (3 - 1); i++) { // 如果不是 3 的倍数
> 			int num = linkedlist.remove(0); // 移除不是 3 的倍数的数,第一次开始为 1
> 			linkedlist.add(num); // 将不是 3 的倍数的数放在最后,第一次开始是把 1 放在 50 之后
> 		}
> 		// 未进入 for 循环,说明是 3 的倍数,则从列表中移除
> 		index = linkedlist.remove(0); 
> 		System.out.println("end : " + linkedlist.size() + " \t index: " + index);
> 	}
> 	// while 循环执行完毕,最后一个人已被移除
> 	System.out.println(index); // 最后一个人开始所站的位置 11
> }
> ```

### 5. 阿姆斯特朗数问题
> #### `例如 153=1^3+5^3+3^3 的数叫做 Armstrong 数,用 java 代码实现输出三位数的 Armstrong 数`
> ``` java
// 同样还是在主方法里调用 :grin: 
> public static void armstrongTest() {
> 	int hundredsDigit,tensDigit,unitsDigit;//hundredsDigit表示数字的百位,tensDigit表示数字的十位,unitsDigit表示数字的个位
> 	System.out.println("寻找Armstrong数:");
> 	for (int i = 100; i <= 999; i++) {
> 		//No.1
> 		//开始写代码,例如153可以满足1^3 + 5^3 + 3^3 = 153,这样的数称为Armstrong数,输出所有三位数中的Armstrong数
> 		hundredsDigit = i / 100; // 获取百位数
> 		tensDigit = (i % 100) / 10; // 十位数
> 		unitsDigit = i % 10; // 个位数
> 		// Math.pow(double a, double b) 返回 a 的 b 次方
> 		if ((Math.pow(hundredsDigit, 3) + Math.pow(tensDigit, 3) + Math.pow(unitsDigit, 3)) == i) // 如果是Armstrong数则输出
> 			System.out.print(i + " ");
> 		//end_code
> 	}
> 	System.out.println();
> }
> ```

### 6. 统计指定类型字符个数
> #### `用 java 代码实现输入一串字符串,统计其中的数字、英文、空格、其他字符个数`
> ``` java
public static void strLength() {
	int digital = 0;//数字个数
	int  character = 0;//英文个数
	int other = 0;//其他字符个数
	int blank = 0;//空格个数
	char[] chars = null;
	System.out.println("这是任意一串字符:");
	String string = "djfiepqo ioghr4 8758495 7123hr37hfjW$@@$@^%!";
	chars = string.toCharArray();
	//No.1
	//开始写代码,计算任意一串字符中的数字个数、英文字母个数、空格个数和其他字符个数
	for (int i = 0; i < chars.length; i++) {
		if(chars[i] >= '0' && chars[i] <= '9') { // 数字
			digital++;
		} else if((chars[i] >= 'a' && chars[i] <='z') || (chars[i] >= 'A' && chars[i] <='Z')) { // 英文字母
			character++;
		} else if(chars[i] == ' ') { // 空格
			blank++;
		} else { // 其他字符
			other++;
		}
	}
	//end_code
	System.out.println("数字个数: " + digital);
	System.out.println("英文字母个数: " + character);
	System.out.println("空格个数: " + blank);
	System.out.println("其他字符个数:" + other);
}
> ```

### 7. 用递归方法计算一个数的阶乘
> #### `给定一个正整数,Java 实现用递归的方法计算它的阶乘`
> ``` java
> public class Test {
> 	public static void main(String[] args) {
> 		int number = 12;
> 		Recursion factorialRecursion = new Recursion();
> 		System.out.println(number + "! = " + factorialRecursion.recursion(number));
> 	}
> }
> //No.1
> //开始写代码,给定一个正整数,用递归的方法计算它的阶乘.main函数已给出,实现Recursion类
> class Recursion {
> 	public int recursion(int number) {
> 		if(number < 0) {
> 			System.out.println("请输入0或正整数!");
> 			return 0;
> 		} else if(number == 1 || number == 0) {
> 			return 1;
> 		} else {
> 			return number * recursion(number - 1);
> 		}
> 	}
> }
> //end_code
> ```
> 
> 艾玛呀,一不小心又到凌晨了....
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1083 引用 • 3461 回帖 • 286 关注
  • 算法
    388 引用 • 254 回帖 • 22 关注
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    324 引用 • 1395 回帖
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3168 引用 • 8207 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • liweiwei

    挺有意思的。

  • 其他回帖
  • someone

    //创建一个集合 list, List
    //把所有人放进去, for(int i = 1;i <= sum;i++)
    //设置将离开的人的下标 int i = 0;
    //退出的人在集合中的下标 i, 因为 list 下标从 0 开始,所以需要 num-1
    //将集合中该人的元素删除

    为什么评论最大只能 200。。。。我几行的代码还得拆分成 3 次发表。。。
    不过我运行出来得结果 50 和 3 传进去得出也是 11 号,跟你结果一致
    很想了解一下你得这种算法,

  • someone

    这第 4 题:用 java 代码实现约瑟夫环问题,50 个人围成一圈报数,报到 3 的倍数的离开,求最后剩下的那个人原来站的位置。
    你的答案没看懂
    你的这个 for 循环判断不是 3 的倍数 for (int i = 0; i < (3 - 1); i++) { // 如果不是 3 的倍数。 它怎么判断的?
    另外 int num = linkedlist.remove(0); // 移除不是 3 的倍数的数,第一次开始为 1 。 linkedlist.remove(int index); 这个方法的返回值是泛型 E,你怎么能不强转直接等于呢?
    然后你的这个算法也没看懂。。。然后我就跟这道题杠上了,,
    花了一个中午的时间拿笔画画写写算算,算是写出来了,下面是我的方案:

  • iTanken

    @88250 也还没睡呢,看来还不晚 😂 😂

    1 回复
  • 查看全部回帖
iTanken
飘风不终朝,骤雨不终日。 北京

推荐标签 标签

  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    34 引用 • 467 回帖 • 693 关注
  • 人工智能

    人工智能(Artificial Intelligence)是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门技术科学。

    75 引用 • 145 回帖 • 1 关注
  • PostgreSQL

    PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。

    22 引用 • 22 回帖
  • Sillot

    Sillot (汐洛)孵化自思源笔记,致力于服务智慧新彖乄,具有彖乄驱动、极致优雅、开发者友好的特点
    Github 地址:https://github.com/Hi-Windom/Sillot

    15 引用 • 6 回帖 • 28 关注
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    70 引用 • 532 回帖 • 712 关注
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    51 引用 • 37 回帖
  • Logseq

    Logseq 是一个隐私优先、开源的知识库工具。

    Logseq is a joyful, open-source outliner that works on top of local plain-text Markdown and Org-mode files. Use it to write, organize and share your thoughts, keep your to-do list, and build your own digital garden.

    4 引用 • 55 回帖 • 10 关注
  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖
  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    59 引用 • 29 回帖 • 18 关注
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    131 引用 • 3639 回帖
  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    140 引用 • 441 回帖 • 1 关注
  • Vue.js

    Vue.js(读音 /vju ː/,类似于 view)是一个构建数据驱动的 Web 界面库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

    261 引用 • 662 回帖
  • 反馈

    Communication channel for makers and users.

    123 引用 • 906 回帖 • 193 关注
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    103 引用 • 294 回帖
  • Caddy

    Caddy 是一款默认自动启用 HTTPS 的 HTTP/2 Web 服务器。

    10 引用 • 54 回帖 • 126 关注
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 89 关注
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖 • 2 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 47 关注
  • Hexo

    Hexo 是一款快速、简洁且高效的博客框架,使用 Node.js 编写。

    21 引用 • 140 回帖 • 28 关注
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖 • 6 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    164 引用 • 407 回帖 • 526 关注
  • 音乐

    你听到信仰的声音了么?

    59 引用 • 509 回帖
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    675 引用 • 535 回帖 • 1 关注
  • 锤子科技

    锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

    4 引用 • 31 回帖 • 10 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖 • 2 关注
  • ZeroNet

    ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

    1 引用 • 21 回帖 • 592 关注
  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1425 引用 • 10043 回帖 • 470 关注