北華大學網路賽題

来源:https://www.cnblogs.com/biaobiao88/archive/2019/12/07/12002836.html
-Advertisement-
Play Games

D題 1 #include<iostream> 2 #include<map> 3 #include<algorithm> 4 #define int long long 5 using namespace std; 6 7 /*解題思路:題中的乘以10的倍數,只是虛晃,可以不用在意,因為只要保證字 ...


 

D題

 

 

 1 #include<iostream>
 2 #include<map>
 3 #include<algorithm>
 4 #define int long long
 5 using namespace std;
 6 
 7 /*解題思路:題中的乘以10的倍數,只是虛晃,可以不用在意,因為只要保證字元串的大小就行了,字元串大的乘以相同大小的數自然還是大的
 8 如果在輸入的字元串中只存在一個最大長度的字元串,比如輸入3個字元串,分別是:abc acb acbb 自然是acbb這個字元串最大,找出來直接輸出即可
 9 如果在輸入的字元串中存在多個相同長度的最大字元串,比如輸入4個字元串,分別是ab abcd abdc accc 可以看出來,abcd這個字元串最大,因為字元串的比較大小直接可以用
10 比較操作符來進行比較,而我們要在後三個字元串中挑出最大的,如何實現呢?
11 將最大長度的字元串都反轉以下,使用reverse反轉函數,上述例子將變為:dcba cdba ccca 再從這裡面找出最大的字元串即可,即為dcba 最後輸出再次反轉回來即可 
12 */ 
13 signed main()
14 {
15     int t;
16     cin >> t;//輸入樣例個數 
17     while(t--)
18     {
19         map<int,int> vis;//使用一個圖,相當於一個vis[]數組,用於存儲最長字元串有多少個 
20         string str[100];//開一個字元串數組,用於存儲輸入的字元串,本題只要大於10即可
21         string ans;//如果存在唯一一個最大字元串長度的字元串,則用於保存它,用於輸出
22         int n;
23         int maxn = 0;//找出最長字元串 
24         cin >> n;//輸入字元串個數 
25         for(int i = 1;i <= n;i++)
26         {
27             string temp;
28             cin >> temp;//迴圈輸入n個字元串
29             int len = temp.size();//得到這個字元串的長度,進行下麵比較操作
30             if(maxn < len)
31             {
32                 ans = temp;//如果有出現暫時是最長的字元串,先記錄到ans中 
33                 maxn = max(maxn,len);//更新maxn的值,使其保持最大狀態 
34             }
35             vis[len]++;//將此時的字元串長度記錄到vis數組中,出現幾個記錄幾個
36             reverse(temp.begin(),temp.end());//將字元串反轉;
37             str[i] = temp;//將反轉後的結果記錄到str字元數組當中 
38         }
39         //判斷最長的字元串是否是一個,是,則直接輸出,否則肯定存在多個相同長度的最長字元串 
40         if(vis[maxn] == 1)
41         {
42             cout << ans << endl;
43             continue;
44         }
45         string res;//res相當於臨時變數,用於存儲最後答案
46         //以下的for操作是在反轉後的字元串中通過字元串比較操作符直接選出最大的字元串 
47         for(int i = 1;i <= n;i++)
48         {
49             if(str[i].size() == maxn)//找出最長的字元串 
50             {
51                 if(str[i] > res)//通過字元串比較操作符進行比較,選出大的記錄在res當中 
52                 {
53                     res = str[i];
54                 }
55             }
56         }
57         reverse(res.begin(),res.end());//由於得出的res是反轉後的,必須再將其反轉回來
58         cout << res << endl; 
59     }
60     return 0;
61 }

E題

 

 

 1 #include<iostream>
 2 #define int long long
 3 #define mod 2019
 4 using namespace std;
 5 int arr[10000000];
 6 
 7 signed main()
 8 {
 9     //在未開始輸入的時候先對數據進行預處理,可大大降低時間複雜度 
10     arr[0] = 3;
11     for(int i = 1;i <= 1000001;i++)
12         arr[i] = (arr[i - 1] * 2) % mod;
13         
14     //等預處理完成後,再進行輸入輸出操作,就簡便多了
15     int t;
16     cin >> t;
17     while(t--)
18     {
19         int n;
20         cin >> n;
21         cout << arr[n - 1] << endl;
22     }
23     return 0;
24 }

 

 


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

-Advertisement-
Play Games
更多相關文章
  • 一、iView(View UI) 1、簡介 官網:https://www.iviewui.com/ 倉庫:https://github.com/view-design/ViewUI iView 與 View UI 本質上是一個東西,隨著版本的升級,iView (4.0)改名為 View UI。是一套 ...
  • 這個博客寫了好多前端的知識,有如下內容 "鏈接" ( ^▽^ )( ^▽^ )( ^▽^ ) "html" "css" "JavaScript" "jQuery" "ajax" "canvas" "nodejs" "mysql" "mongodb" "angular" 還有一些數據結構的知識和pyt ...
  • 作者:個人微信公眾號:程式猿的月光寶盒 項目中使用了Mybatis的PageHelper分頁插件後的js文件 js / 初始化首頁數據 / function initData(pageNo) { //清空原來的數據,找到第一個以外的tr,並移除,用 :gt() $("tr:gt(0)").remov ...
  • 1.Ajax非同步按下回車提交表單;2.isEmpty()判斷input框是否為空 ...
  • 首發於微信公眾號《前端成長記》,寫於 2019.12.06 背景 本文記錄刷題過程中的整個思考過程,以供參考。主要內容涵蓋: 題目分析設想 編寫代碼驗證 查閱他人解法 思考總結 目錄 "100.相同的樹" "101.對稱二叉樹" "104.二叉樹的最大深度" "107.二叉樹的層次遍歷II" "10 ...
  • 1.Decompose Conditional (分解條件表達式)應用場景:你有一個複雜的條件(if-then-else)語句。從if、then、else三個段落中分別提煉出獨立函數。示例:if (date.before(SUMMER_START) || date.after(SUMMER_END) ...
  • 二分法是一種高效的查找方法,其適用於 已經排好序 的數組 基本思路 從數組最中間的數開始查找判斷,若不是需要查找的數字,則比較大小,之後則在從中間分開的兩邊中的一邊從最中間開始查找判斷,以此類推 演算法描述 這裡以升序數組為例,降序數組類似 1. 記錄數組最中間數的下標,將其中的數與要查找的數進行比較 ...
  • 今天學了Jedis的相關內容,然後做了一個案例,但是出現了錯誤,然後我百度了一晚上沒有解決,想到看看發個博客能不能有大佬幫我看一下問題出現在哪裡,百度了一晚上有點懵逼。求大佬幫我解決,在這小弟我先萬分感謝大佬們點進來幫我看,感謝大佬們~ 下麵是案例需求: 案例需求: 1. 提供index.html頁 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...