ccf題庫中2015年12月2號消除類游戲

来源:http://www.cnblogs.com/JsonZhangAA/archive/2017/11/20/7868535.html
-Advertisement-
Play Games

題目如下: 這題思路比較簡單,我們可以寫一個檢測函數func來測試一位數組中重覆元素大於或等於3的情況。然後在主函數中分別對每列和每行執行func運算。 代碼如下: ...


題目如下:

問題描述
  消除類游戲是深受大眾歡迎的一種游戲,游戲在一個包含有n行m列的游戲棋盤上進行,棋盤的每一行每一列的方格上放著一個有顏色的棋子,當一行或一列上有連續三個或更多的相同顏色的棋子時,這些棋子都被消除。當有多處可以被消除時,這些地方的棋子將同時被消除。
  現在給你一個n行m列的棋盤,棋盤中的每一個方格上有一個棋子,請給出經過一次消除後的棋盤。
  請註意:一個棋子可能在某一行和某一列同時被消除。
輸入格式
  輸入的第一行包含兩個整數n, m,用空格分隔,分別表示棋盤的行數和列數。
  接下來n行,每行m個整數,用空格分隔,分別表示每一個方格中的棋子的顏色。顏色使用1至9編號。
輸出格式
  輸出n行,每行m個整數,相鄰的整數之間使用一個空格分隔,表示經過一次消除後的棋盤。如果一個方格中的棋子被消除,則對應的方格輸出0,否則輸出棋子的顏色編號。
樣例輸入
4 5
2 2 3 1 2
3 4 5 1 4
2 3 2 1 3
2 2 2 4 4
樣例輸出
2 2 3 0 2
3 4 5 0 4
2 3 2 0 3
0 0 0 4 4
樣例說明
  棋盤中第4列的1和第4行的2可以被消除,其他的方格中的棋子均保留。
樣例輸入
4 5
2 2 3 1 2
3 1 1 1 1
2 3 2 1 3
2 2 3 3 3
樣例輸出
2 2 3 0 2
3 0 0 0 0
2 3 2 0 3
2 2 0 0 0
樣例說明
  棋盤中所有的1以及最後一行的3可以被同時消除,其他的方格中的棋子均保留。
評測用例規模與約定
  所有的評測用例滿足:1 ≤ n, m ≤ 30

這題思路比較簡單,我們可以寫一個檢測函數func來測試一位數組中重覆元素大於或等於3的情況。然後在主函數中分別對每列和每行執行func運算。

代碼如下:

#include<stdlib.h>
#include<iostream>
using namespace std;
void func(int * s,int len){
    int count=0;
    int i;
    for(i=0;i<len-1;i++){
        if(s[i]==s[i+1]||(s[i]-10)==s[i+1]||s[i]==(s[i+1]-10)){
            count++;
        }else{
            if(count>=2){
                for(int j=0;j<=count;j++)
                {
                    s[i-j]+=10;
                }
                count=0;
            }else{
                count=0;
            }
        }
    }
    if(i==len-1&&count>=2){
        for(int j=0;j<=count;j++)
        {
            s[i-j]+=10;
        }
    }
}
int main()
{
    int m,n;
    cin>>n>>m;
    int s[n][m];
    for(int i=0;i<n;i++){
        for(int j=0;j<m;j++){
            cin>>s[i][j];
        }
    }
    //-------------func--------------------
    for(int i=0;i<n;i++)
    {
        func(s[i],m);
    }
    for(int i=0;i<m;i++)
    {
        int temp[n];
        for(int j=0;j<n;j++){
            temp[j]=s[j][i];
        }
        func(temp,n);
        for(int j=0;j<n;j++){
            if(temp[j]>10){
                s[j][i]=temp[j];
            }
        }
    }
    //------------------show result------------------
    for(int i=0;i<n;i++){
        for(int j=0;j<m;j++){
                if(s[i][j]>10)
                {
                    s[i][j]=0;
                }
                cout<<s[i][j]<<" ";
        }
        cout<<endl;
    }
    return 0;
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文主要介紹JDK環境配置、Sublime Text3配置及第一個HelloWorld.Java程式。運行環境為Win10系統,使用JDK1.8版本。 ...
  • VS2008創建MFC程式 1. 點擊菜單欄 文件 新建 項目 選擇MFC應用程式 MFC ActiveX 控制項用來生成MFC ActiveX控制項程式。 MFC應用程式用來生成MFC應用程式。 MFC DLL用來生成MFC動態鏈接庫程式。 2. 填好項目名稱,存儲位置後點擊確定進入MFC應用程式嚮導 ...
  • 1.深淺拷貝 在Python中將一個變數的值傳遞給另外一個變數通常有三種:賦值、淺拷貝、深拷貝 Python數據類型可氛圍基本數據類型包括整型、字元串、布爾及None等,還有一種由基本數據類型作為最基本的元素所組成的像列表、元組、字典等。 在Python中基本數據類型的賦值、深淺拷貝沒有任何意義,都 ...
  • 通過下麵一個例子進行理解。 運行結果: 分析: p = multiprocessing.Process(……)定義了五個進程,p.start五個進程並行,造成如圖的結果是信號量限制進程對臨界資源的訪問的原因。 s = multiprocessing.Semaphore(2)定義了信號量最大為2,re ...
  • 前言 今天要總結的就是Mybatis的相關簡單入門,並且使用這個持久化框架解決一些JDBC原生代碼產生的問題。 一、Mybatis介紹 MyBatis本是apache的一個開源項目iBatis,2010年這個項目由apache software foundation 遷移到了google code, ...
  • 定義 原型(Prototype Pattern)是一個簡單的設計模式。原型模式的英文原話是:Specify the kind of objects to create using a prototypical instance,and create new objects by copying th ...
  • 測試環境 本次測試直接host指定功能變數名稱,然後在虛擬機中安裝了三台CentOS。 測試功能變數名稱 :a.com A伺服器IP :192.168.0.108(主) B伺服器IP :192.168.0.27 C伺服器IP :192.168.0.131 部署思路A伺服器做為主伺服器,功能變數名稱直接解析到A伺服器(192 ...
  • 前面的隨筆中我們經常會改setting配置也經常將一些配置混淆今天主要是將一些常見的配置做一個彙總。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...