2020年04月19日個人賽

来源:https://www.cnblogs.com/blogxsc/archive/2020/04/23/12764654.html
-Advertisement-
Play Games

A - Buggy Sorting 題意:這個題意就是給你一個錯誤的排序方式,要求你在它的這個排序方式下判斷是否存在正確的運行結果。若存在正確的結果,則輸出-1,否則輸出一個例子說明是錯誤的。題目的輸入是元素的個數n。 題解:這一題比較有意思,很容易判斷出只有當n=1 or n=2時運行結果是正確的 ...


A - Buggy Sorting

題意:這個題意就是給你一個錯誤的排序方式,要求你在它的這個排序方式下判斷是否存在正確的運行結果。若存在正確的結果,則輸出-1,否則輸出一個例子說明是錯誤的。題目的輸入是元素的個數n。

題解:這一題比較有意思,很容易判斷出只有當n=1 or n=2時運行結果是正確的,其餘的情況都是錯誤的。這樣我們就構造出一個序列出來就可以了。

代碼:

#include<iostream>
#include<stdio.h>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
int main(){
    int n;
    cin>>n;
    if(n<=2){
        cout<<-1;
    }else{
        for(int i=n;i>=1;i--){
            cout<<i;
            if(i!=1){
                cout<<" "; 
            }
        }
    }
    return 0;
} 

B - Increase and Decrease

題意:這一題的大概意思是給你一個長度為n的int序列。你可以選擇其中任意兩個數對其分別進行+1和-1操作,問在進行若幹次後,最多可存在多少個相同的數。

題解:對同一個數組裡面的兩個元素進行+1和-1操作,很容易想到的一點是它的元素和總是一定的,這是一個突破點。這裡我們判斷元素的和是否能被n整除,如果能,則最多的個數就是n(說明一定存在某種方式將所有的元素變為一樣的),如果不能,就肯定存在一個餘數,這時,我們就可以捨去這個元素,對其他的元素進行操作。則此時的元素個數就是n-1。

代碼:

#include<iostream>
#include<stdio.h>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
int main(){
    int n;
    cin>>n;
    int num[100005]={0};
    int sum=0;
    for(int i=0;i<n;i++){
        cin>>num[i];
        sum=sum+num[i];
    }
    if(sum%n==0){
        cout<<n<<endl;
    }else{
        cout<<n-1<<endl;
    }
    return 0;
} 

E - Dividing Orange

題意:這一題的大概意思是k個人平均分n*k個橘子,特別的是每個人都有它們各自必須必須需要的一個橘子,其他的沒有要求。

題解:這一題也是比較簡單的(悔不當初),

代碼:這裡我們只需要用一個vis數組記錄一下哪一個橘子被分了就可以,然後依次輸出應有數量的橘子即可(同時特別關註該人特別需要橘子的編號這個需要特別判斷一下)。

代碼:

#include<iostream>
#include<stdio.h>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
int main(){
    ll n,k;
    cin>>n>>k;
    int num[1000]={0};
    int vis[1000]={0}; 
    int t;
    for(int i=0;i<k;i++){ 
        cin>>vis[i];
        num[vis[i]]=1;
    }
    int len=0;
    for(int i=0;i<k;i++){
        len=0;
        cout<<vis[i]<<" ";
        len++;
        for(int j=1;j<=n*k;j++){
            if(len<n&&num[j]==0){
                cout<<j;
                num[j]=1;
                len++;
                if(len<=n-1){
                    cout<<" ";
                }
            }
        } 
        cout<<endl;
    } 
    return 0;
} 

F - Undoubtedly Lucky Numbers

題意:這一題的大概意思它定義了一種特別的數,其中這個數字包含的單個數字的種類的數量不超過2種,現在給你n需要你求出在[1,n]之中存在多少個這樣的數字。

題解:比賽想了半天就是沒看出這是一個dfs,這裡我們可以這樣想,我們遍歷[0,9]中全部的2種數字的組合,然後將它們去排列組合,小於n就放入set(可以去重)中,最後輸出就可以了。

知識點:dfs 排列組合

代碼:

#include<iostream>
#include<set>
#include<algorithm>
#define ll long long
using namespace std;
set<ll> st;
ll n;
void dfs(int a,int b,ll num){
    st.insert(num);
    ll ta=num*10+a;
    ll tb=num*10+b;
    if(ta&&ta<=n){
        dfs(a,b,ta);
    }
    if(tb&&tb<=n){
        dfs(a,b,tb);
    }
}
int main(){
    cin>>n;
    for(int i=0;i<=9;i++){
        for(int j=0;j<=9;j++){
            dfs(i,j,0);/*每個數字都是從0開始的*/
        }
    }
    cout<<st.size()-1;
    return 0;
}

 


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

-Advertisement-
Play Games
更多相關文章
  • 在Visual Studio Code 1.設置. show tabs 取消打勾,再次打勾 2.關閉預覽功能。 設置中搜索 workbench.editor.enablePreview ,找到此項後,保持不勾選狀態,這樣就會關閉了預覽模式,打開的文件都會生成新的標簽頁。 參考: https://bl ...
  • 把拖動div功能用react封裝成class,在頁面直接引入該class即可使用。 title為可拖動區域。panel為要實現拖動的容器。 優化了拖動框超出頁面範圍的情況,也優化了拖動太快時滑鼠超出可拖動區域的情況,優化了拖動會卡頓的情況。 頁面中添加引入方法: <Draggable panelId ...
  • 最近客戶反映頁面會有亂碼的情況,查看後發現只有英文大寫字母亂了 谷歌瀏覽器有翻譯功能,在翻譯成中文後會出現這種情況。 <html id="html" lang="zh-CN">之前lang=“en”,如果瀏覽器設置了總是詢問,在檢測到是en後會提示是否翻譯。發現在翻譯後,html的lang會變化,然 ...
  • 前端是什麼? 工作流程為從UI處得到原型圖或者效果圖,在項目(網站、微信公眾號、小程式、WEBAPP)中還原圖片效果,然後與後臺進行各種數據交互。 目前的前端市場整體還是處於迅速發展期,市場對於前端的需求也一直比較大。市場對於中高級的前端工程師需求更加迫切,所以就算入了前端的門,也需要不斷的提升自己 ...
  • 一、垃圾回收機制的必要性 由於字元串、對象和數組沒有固定大小,所以當它們的大小已知時,才能對它們進行動態的存儲分配。JavaScript程式每次創建字元串、數組或對象時,解釋器都必須分配記憶體來存儲那個實體。只要像這樣動態地分配了記憶體,最終都要釋放這些記憶體以便它們能夠被再用,否則,JavaScript ...
  • 一、什麼是架構 我想這個問題,十個人回答得有十一個答案,因為另外的那一個是大家妥協的結果,哈哈,我理解,架構就是骨架,如下圖所示: 人類的身體的支撐是主要由骨架來承擔的,然後是其上面的肌肉、神經、皮膚。架構對於軟體的重要性不亞於骨架對人類身體的重要性。 二、什麼是設計模式 這個問題我問過的面試者不下 ...
  • 1.事務控制的理解 事務控制的慨念這裡不作說明。事務控制的不好可能會造成資料庫數據的臟讀,污讀 舉個例子:轉賬的功能 張三給李四轉錢,各自的賬號金額操作完成後,需要各自更新到資料庫,此時如果張三更新完後,程式異常了結束了,使得李四的賬戶沒有更新,使得總金額不對 為了控制這種數據的不合理,引進了事務。 ...
  • 題目翻譯 現在,你需要求出A,B兩個多項式的相加結果。 輸入要求 每一個輸入文件包含一個測試樣例。每一個樣例占兩行並且每行包含多項式的信息: $K\space N_1 \space a_{N_1}\space N_2 \space a_{N_2} \space ...\space N_k \spac ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...