猿问

如何检查单行输入中是否有两个相同的数字

我正在使用 eclipse 在 java 中制作扑克游戏,我需要帮助创建代码来查找单行输入的 PAIR。如果用户输入:12,11,5,2,12那么我如何识别输入是否有两个相同的数字,然后将其打印为一对。

所以基本上我已经接受了一个字符串输入,然后使用 split 函数将其转换为 String 数组以识别数字,然后将其转换为 Int 数组。

当用户输入:12,3,4,5,12-- 它应该在输出中打印:PAIR


素胚勾勒不出你
浏览 180回答 5
5回答

慕哥6287543

尝试使用一套。一个元素只能包含在集合中一次,因此如果数组中有重复的数字,contains()则会返回。truepublic static void findPairs(int[] numbers) {&nbsp; Set<Integer> set = new HashSet<>();&nbsp; for (int number: numbers) {&nbsp; &nbsp; if (!set.add(number)) {&nbsp; &nbsp; &nbsp; System.out.println("PAIR: " + number);&nbsp; &nbsp; }&nbsp; }}请记住,如果您的数组包含超过 2 个相同数字的重复项,则这将打印PAIR: n多次 - 它不会在列表中找到给定数字的多个重复项。在这种情况下,您可能需要考虑删除该号码并跟踪您已经捕获的对。

拉丁的传说

只需使用一个集合,然后添加元素即可。如果 add 返回 false,则存在欺骗,您可以执行任何您想要的逻辑。Set<String> cards = new HashSet<>();if (!cards.add(something))  {    // match of two cards found}如果您需要它是数字,请使用 Integer,而不是 int,因为后者是基元而不是 obj。

明月笑刀无情

您可以使用一个数组,其中位置+1是卡片的编号,例如:5 5 10 11 7[0, 0, 0, 0, 2, ... , 1, 0, 0, 1, 1,...]

猛跑小猪

用户输入是如何存储的。例如,将其存储为数组,然后将按要求输出以下内容。public static void main(String[] args) {&nbsp; &nbsp; int[] nums = new int[]{12,11,5,2,12};&nbsp; &nbsp; System.out.println(isPair(nums));}private static String isPair(int[] nums){&nbsp; &nbsp; Set<Integer> set = new HashSet<>();&nbsp; &nbsp; for(int n : nums){&nbsp; &nbsp; &nbsp; &nbsp; if(set.contains(n)){&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; return "PAIR";&nbsp; &nbsp; &nbsp; &nbsp; }else{&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; set.add(n);&nbsp; &nbsp; &nbsp; &nbsp; }&nbsp; &nbsp; }&nbsp; &nbsp; return null;}

沧海一幻觉

正如其他答案所指出的,使用 Set 可以很容易地找到重复项,但无法区分一对、三条和四边形之间的区别,或者两对和葫芦之间的区别。它也无助于找到剩下的扑克牌。更好的方法是简单地对用于表示卡片的数字数组进行排序,然后迭代排序的列表,查找对和三元组(现在将是相邻的)。这也将帮助您寻找顺子,并有助于在相似牌之间进行排名。另外,通常最好从上到下寻找手牌:即,检查同花顺,然后四边形,然后葫芦,然后同花......一直到一对和没有对。
随时随地看视频慕课网APP

相关分类

Java
我要回答