日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

去哪儿笔试:座位安排问题

發布時間:2023/12/8 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 去哪儿笔试:座位安排问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

去哪兒筆試:座位安排問題

題目描述

假設一個教室有m * n 個座位,每個座位上可以座一個學生。前提是座位沒有壞掉,沒壞的座位用’.’表示,壞掉的座位用’x’表示。

現在要在這個教室安排考試,由于坐在(x,y)位置上的同學能夠抄到(x-1,y-1)、(x-1,y+1)、(x,y-1)、(x,y+1)的同學,所以要把他們分開安排。現在讓我們計算出,這個教室能夠最多安排多少人。

輸入樣例

2 3

輸出樣例

4

思路

從左上角的位置開始安排

  • 首先判斷是不是壞掉的座位,如果是則不能安排人
  • 然后判斷能不能抄襲到別人

import java.util.*;public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int m = sc.nextInt();int n = sc.nextInt();sc.nextLine();char[][] arr = new char[m][n];for(int i = 0; i < m; i++) {String line = sc.nextLine();char[] c = line.toCharArray(); for(int j = 0; j < n; j++) {arr[i][j] = c[j]; }}int[][] dp = new int[m+2][n+2];int count = 0;for(int i = 1; i <= m; i++) {for(int j = 1; j <= n; j++) {if(arr[i-1][j-1] == 'x') { // 如果座位壞掉了continue;}// 判斷能不能抄襲到別人if(dp[i-1][j-1] == 0 && dp[i-1][j+1] == 0 && dp[i][j-1] == 0 && dp[i][j+1] == 0) {dp[i][j] = 1;count++;}}}for(int i = 0; i <= m; i++) {for(int j = 0; j <= n; j++) {System.out.print(dp[i][j]+" ");}System.out.println();}System.out.println(count);}}

總結

以上是生活随笔為你收集整理的去哪儿笔试:座位安排问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。