消消乐笔试--20190611记

##在线笔经##
前天消消乐笔试,题目是接收输入的带空格的n个Int类型的数字,生成链表,再进行排序。

输入如下代码即可,后台自动处理链表的生成,再使用insertionSortList函数进行排序。
如果排序方法不是该名称,会报错提示。链表结点的声明不是ListNode,也会报错。node的两个字段也必须是next和val,别的不行。。。

public static ListNode  insertionSortList(ListNode head){		
		if(head == null ||  head.next == null)
			return head; 		
		ListNode  p1 = head;
		ListNode  p2 = head.next;
		while(p1.next != null){
			while(p2 != null){
				if (p2.val < p1.val) {
					int tmp = p2.val;
					p2.val = p1.val;
					p1.val = tmp;
				}
				p2 = p2.next;
			}
			p1 = p1.next;
			p2 = p1.next;
		}		
		return head;
	}
    

如果自己写了接收字符和生成链表的方法,可以用自己的Main函数。

public class Solution {
	public static ListNode  insertionSortList(ListNode head){		
		if(head == null ||  head.next == null)
			return head; 		
		ListNode  p1 = head;
		ListNode  p2 = head.next;
		while(p1.next != null){
			while(p2 != null){
				if (p2.val < p1.val) {
					int tmp = p2.val;
					p2.val = p1.val;
					p1.val = tmp;
				}
				p2 = p2.next;
			}
			p1 = p1.next;
			p2 = p1.next;
		}		
		return head;
	}
    
    
    public static void printList(ListNode head){
		while(head!=null){
			System.out.print(head.val+" ");
			head = head.next;
		}
		
	}
    
    public void Main(String[] args) {
		Scanner sc = new Scanner(System.in);
		ArrayList<Integer> array = new ArrayList<Integer>();
		String s = sc.nextLine();
		String[] s1 = s.split(" ");
		for (int i = 0; i < s1.length; i++) {
			array.add(Integer.valueOf(s1[i]));
		}
		
		ListNode head = new ListNode(s1.length);
		ListNode p = head;
		
		for (int i = 0; i < array.size(); i++) {
			ListNode node = new ListNode(array.size());
			node.val = array.get(i);
			node.next = null;
			p.next = node;
			p = node;
		}
		insertionSortList(head.next);
		
		printList(head.next);
}
}

也可以正常编译运行通过!

再者,网上搜到一种方法,是摘节点再插入,比较麻烦(也是一种思想),如下:

public class SolutionForInsertNode {
	Node myHead;

	public Node insertionSortList(Node head) {
		Node cursor = head;
		myHead = head;
		while (cursor != null) {
			Node temp = cursor.next;
			if (temp != null && temp.value < cursor.value) { // 如果该结点的后一个结点比该节点小
				cutLink(cursor); // 将后一个结点从链表中取出
				insertNode(temp, head); // 将后一个结点插入到适合的位置
			} else {
				cursor = cursor.next;
			}
		}
		return myHead;
	}

	public void cutLink(Node one) {
		Node two = one.next;
		Node three = two.next;
		one.next = three;
		two.next = null;
	}

	public void insertNode(Node node, Node head) {
		Node temp = myHead;
		Node pre = null;
		while (node.value > temp.value) {
			pre = temp;
			temp = temp.next;
		}
		node.next = temp;
		if (pre != null) {
			pre.next = node;
		} else {
			myHead = node;
		}
	}

}

!!!
在线编程和本地编程,差别真大!!!
!!!

注意事项:

  • 题目有多个类型的(有的笔试会有很多题目类型,先做编程或者先做问答或者先做代码填空,需要根据情况选择顺序。)
  • 自己写主函数要写成Main
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很高兴为您提供Unity 3D游戏-消消乐(三消类)教程和源码。 首先,您需要安装Unity 3D引擎,然后创建一个新的项目。接下来,您可以按照以下步骤构建您的游戏: 1. 创建一个3D场景并添加相机和灯光。 2. 创建一个游戏板,可以使用网格和材质来创建。 3. 创建不同的游戏块,可以使用3D模型或2D图片来创建。 4. 实现游戏规则:当三个或三个以上相同的块相邻时,它们将被消除。 5. 实现游戏的分数系统和难度级别。 这是一个基本的游戏框架,您可以根据需要添加其他功能和元素。 此外,以下是一个基于Unity 3D的消消乐游戏的源代码示例,您可以将其作为参考: ```csharp using UnityEngine; using System.Collections; public class Block : MonoBehaviour { public enum BlockType { Red, Green, Blue, Yellow } public BlockType blockType; private bool isClicked = false; void OnMouseDown() { if (!isClicked) { isClicked = true; StartCoroutine(CheckMatches()); } } IEnumerator CheckMatches() { yield return new WaitForSeconds(0.1f); GameObject[] blocks = GameObject.FindGameObjectsWithTag("Block"); ArrayList matches = new ArrayList(); foreach (GameObject block in blocks) { if (block != gameObject && block.GetComponent<Block>().blockType == blockType) { float distance = Vector3.Distance(transform.position, block.transform.position); if (distance < 1.1f) { matches.Add(block); } } } if (matches.Count > 0) { matches.Add(gameObject); foreach (GameObject block in matches) { Destroy(block); } } else { isClicked = false; } } } ``` 此代码演示了如何检测匹配块并将其销毁。当用户单击块时,它将检查所有相邻的块,并将其添加到一个数组中。如果匹配块的数量大于0,则将它们全部销毁。否则,单击状态将被重置。 希望这可以帮助您开始创建自己的消消乐游戏!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值