主頁 >  其他 > 課程總結 第六周

課程總結 第六周

2021-04-17 16:21:11 其他

識訓:
尼姆博奕:看了好多博客,開始還是比較容易理解,深層面的較難看懂,尤其是尼姆博奕的變型,還有后面涉及SG打表那一塊,總結一下自己的認識,簡單的跳過,
先看奇異局勢,(s[1],s[2],s[3]…… s[n]),逐步進行異或運算,
若結果為0:那么先手必敗;若不為0,那么先手必勝,(也就是說面對奇異局勢的人必輸)

階梯博弈演算法(尼姆博弈進階):啃了兩三天,頭都暈了,證明程序也看的迷迷糊糊,
題目形式:一個樓梯上每層都放有一些石子(硬幣也可),每回合將i臺階上石子移動到(i-1)階上,最后無法移動的輸,也就是其他階都為空,移動第一階得人贏,
公式:所有的奇數階上的石子進行異或運算>0,則確定是勝方,因為對于敗方來說,若移動奇數階的石子,勝方便有可將奇數階石子異或為0,成為奇異局勢;若移動偶數階石子,勝方可將敗方移動的石子往前移動,對奇數階石子無影響,

到這里還好,可根據階梯博弈變化的題目真的很難,看都看不明白,會繼續認真看的,
舉一個階梯博弈變化的題目,一個盒子從1到n被標記,滿足:
(A>B&&(A+B)%2==1&&(A+B)%3==0),不能移動盒子的人輸,

我的思路:想到了階梯博弈,可還是不會用,發現條件可轉化為(A+B)%6==3,然后舉例了1到15數字的移動情況,不難發現最終都會移動到(1,3,4)這個盒子中,經查閱資料:發現要對所有奇數步盒子的禮品數進行異或運算,而所有滿足奇數步盒子都滿足*(A+B)%6==0或2或5*,這一步簡直太難想了!!

威佐夫博弈:核心公式:(1.0+sqrt(5.0))/2*(a-b) 大體是兩堆石頭,要么從一堆中取任意數,要么從兩堆中取相同數目,先去玩的獲勝,這里的奇異局勢和尼姆博弈的很像,但沒有尼姆博弈難,畢竟尼姆博弈是從n堆石頭中取,
需要注意的點:
1.從一堆中取可能可以得到奇異局勢,2.從兩堆中取一樣的石頭也可能得到奇異局勢,要根據題目要求靈活改變,

k倍動態減法:這個同樣非常難,看了好久都還是很懵,也能看做是斐波那契博弈的變型,只是不再是兩倍了,當k=1時,2的i次方都是必敗點,將n化為用二進制,每次拿走最后的一個1,而對手不能拿走倒數第二個1,因為他拿的數量不能多于你拿的;當k=2時,斐波那契數列都是必敗點;當k>=3時,開兩個陣列a[n],b[n],a[n]存的數字都是必敗點,b[t]是a[1到t]所能表示的最大數,最后要使得

b[i]=b[t]+a[i] (a[t]*k<a[i]

具體實作代碼:(還沒完全理解),目前還是先記住再說,適用性廣

while(n>a[i])
        {
            i++;
            a[i]=b[i-1]+1;
            while(a[j+1]*k<a[i])
                j++;
            if(k*a[j]<a[i])
                b[i]=b[j]+a[i];
            else
                b[i]=a[i];
        }

記憶化搜索:看了很多資料,感徑訓是難在理解遞回式狀態轉移方程那里,
1.概念其實很好理解,搜索程序中,避免重復計算,記錄一些狀態的答案,在接下來狀態中可以直接使用,2.記憶化搜索只是類似于動態規劃,不是屬于,具體是倒著的遞推式動態規劃,

題G:

Y題識訓:題意省略
1.開一個二維陣列,如果要對其中某一行進行初始化memset(dp[1],0,sizeof(dp[1]));這個代碼是可以實作的,但要注意:只能初始化為0,若初始化為1或其他數,會出現亂碼,
2.然后就是我的思路:首先確定要定義一個二維陣列dp[i][j],想到用i來控制最大值為多少的方案數案數,j來表示具體取得末尾的數字,記錄的是方案數,當i等于k時,表示最大數字為k,再從1到n遍歷所有方案數累加
大致思路沒問題,有些細節沒想到:1.如何控制取得的數,由于題目中后一個數字要整除前一個數字,于是又要加一重回圈來控制乘的跨度(1,2,3…),問題看似處在代碼實作上,其實還是思路沒想好,
3.就是取模要及時,每次累加都要,一個注意點,

F題識訓:給定一個字母矩陣,規定可替換的字母,要求所有字母一樣的最大子矩陣的面積,(花了一個上午,弄得我心累的一題)
首先是題意:和我理解的有偏差,我并沒從題目看出求面積的意思,我認為只要求出最大子矩陣相同字母的個數即可,----->>>方向上就錯了,雖然自己也不太會做,
我的思路:雖然自己沒思路,但也想了好久,我發現,替換的情況有很多,肯定是分類討論,也想到了將字母全變成a或b或c,全變成a去找最大子矩陣(b,c同理),到這里是對的,然后我想直接去找字母見得關系,比如最大子矩陣a,如果左邊或上邊是a累加1,其實行不通,這只是在記錄a的次數而已,
查了題解后,題解都看了好久才懂,很多困擾的難點都有了解釋,
1.為了方便記錄,用數字代替字母,出現a則標記為1;然后先只考慮縱向上a出現的次數,若a上方也是a,累加1,

2.更妙的是他計算面積的方式,因為在步驟1中考慮了縱向,接下來考慮橫向就好,dp[i][j]是第i行第j個字母,所表示的值便是這個子矩陣的高,以它為中心,然后向右取比它大的,向左取比它大的,得到最大寬,計算面積取最大,是之前沒見過的查找方式!!!(關鍵是另外開兩個陣列)

 for(int j=1;j<=n;j++)
       {
           while(dp[i][j]<=dp[i][l[j]-1])
            l[j]=l[l[j]-1];
       }
       for(int j=n;j>=1;j--)
       {
           while(dp[i][j]<=dp[i][r[j]+1])
            r[j]=r[r[j]+1];
       }

L - Sonya and Problem Wihtout a Legend 識訓:
本題用了離散化和一些數學知識,看完資料后,才懂了一點,慢慢用到了高數知識和結論了,題意:要求用最少的步數構造一個嚴格的上升陣列,
數學結論:如果是上升陣列,肯定滿足 (a[j]-a[i])>=(j-i),所以便得到 (a[j]-j)>=(a[i]-i),所以用陣列b[n]存盤(a[i]-i)的值,并進行排序,abs(a[i]-b[j])為正在處理第i位時以b[j]為基準最小花費步數,而dp[i][j]為處理到第i位時以b[j]為基準總體上最小花費步數,是需要加上 上一步同樣以b[j]為基準總體上最小花費步數,和同樣處理到第i位時以b[j-1]為基準最小花費進行比較取最小,
構造狀態轉移方程:dp[i][j]=min(dp[i][j-1],dp[i-1][j]+abs(b[j]-a[i]));

4.14訓練賽:
1.我負責的那道題沒有過,因為忽略了一種情況,一直卡住,所以比別人少做一道題,很自責,加油吧!!!
思路:大致都是對的,兩端的樹就往兩邊倒,中間的樹減去相應距離或加上相應距離不和兩端的樹相交,然后累加,之所以沒過:非要用ans去記錄才差值想著方便一點,結果把自己搞暈了,因為ans的值需要不斷更新,
2.D題我的思路是找規律,規律已經快出來了,但還需要時間,隊友直接模擬,我覺得也很好,卡住我們的難點:要過菜品個數進行排序(保證剩余的的菜品先進行配對,這樣才能保證最多,參考樣例:2 3 2),
3.A題我們思路是完全正確的,但是代碼實作上有問題,就被擱置了,沒想到別人都過了,特別虧,其實代碼實作也很簡單,一個數找0和8,2個數兩重回圈列舉遍歷,三位數類似,
教訓:
1.有些問題是自己想得復雜,不是題目復雜,可能和心態有關,心態要放平,
2.如果確定思路正確,就不要輕易的放棄代碼實作,代碼是可以慢慢調的,
3.我負責那題就是我把問題復雜化,定義了一個ans記錄位置

4.15訓練賽:
1.一個代碼實作出現了問題,整個隊浪費了將近40多分鐘,忽略了一個問題,如果這個‘1’是在最后出現的,那么沒有一個‘0’去累加這組1的長度,難受了!

**4.16訓練賽:**主要兩個差距,前半段一直是領先的,后面心態問題特別著急,導致一個簡單題目沒做出來:另一個是H題,沒寫出來,和其他組的差距,要努力追趕并超越!!!
H題:
兩方面原因:1.看題不仔細,看的有點快,沒發現輸入一欄中的條件
1<=b[i]<=2n,2.還有就是代碼實作,沒法將思路很好的轉化,識訓到一個沒想到的代碼實作形式,

for(int i=1;i<=n;i++)
        {
            cin>>a[i];
            m[a[i]]=1;    //將出現的元素標記!!
        }
        int temp;
        for(int i=1;i<=n;i++)
        {
            b[i*2-1]=a[i];      //若一個陣列是另外一個陣列的兩倍,可根據特征記錄)
            temp=a[i];
            while(m[temp]==1)
            {
                temp++;
            }
     (后面代碼就很平常,省略)

技巧,注意點
1.除要用double,
2.異或運算
1.異或的一個運算規律: A^B=C --->>> C^B=A;
2.‘^’ 的優先級小于 '> , <',注意加 '( )'

賽后補題:(不放代碼,主要是思路,錯誤的點和識訓)
一.C. Divisibility by Eight
思路:是完全正確的,能被8整除的數:1000+b;只要保證b能被8整除即可,分別遍歷1位數,2位數,3位數.(采用回圈方式,暴力做即可)
錯誤的點:個位如果取了這個數字,十位數是從這個數字前開始取,百位也是從十位取得數之前取,
識訓:(整理一下數字特征)
能被2整除的數:奇,偶取模于2即可,
能被3整除的數:各個位上數之和能被三整除,
能被4整除:最末兩位數字能被4整除即可,
能被5整除:末位為0或5.
能被6整除:同時能被2和3整除的條件,即是偶數,且各個位數之和能被3整除,“12”同理,
能被7整除:abc def ghi jkl,滿足(jkl-ghi+def-abc)能被7整除,“13”同理,
能被8整除:最后三位數字能被8整除,
能被9整除:各個數字之和能被能被9整除,
能被10整除:末位為0,
可被11整除:(奇位數字和-偶位數字和)能被11整除,

二:B. Balanced Array(水題跳過,過了一遍代碼,當時敲的時候思路不清,整理一下)

三…A. Candies(水題,唯一要注意的點)
識訓:pow()函式的計算方式存在誤差
---->>>處理方式:加上一條常變數const int eps=1e-6; (放主函式外面),不然就用double

四:C. Alternating Subsequence
我的思路:
1.首先要保證取得子段最長,將觀察發現,如果第一個元素是正,那么最長的便是“+-+-+-+-”這種形式;如果第一個元素是負,那么最長的便是“-+-+-+-+-+”這種,
2.之后兩種實作方式,第二種更巧妙一些,都是找同符號下最大的元素累加,
關鍵實作方式:如果找到了正號下最大的元素,那么是在負號陳述句中加;同理,負號最大的元素在正號陳述句中加,不然無法實作加和最大,卡了好久,還有最后的和并未加上最后一個找到的同符號最大值,
第二種實作形式:用乘積來判斷正負號,如果和前一項同號,乘積為正,然后找最大值;之后再乘積為負的時候加上去,

五.Tetrahedron
做了那么多的dp題目,發現自己根本就不會dp!!!學的好亂,一定要花時間整理,即使本題是一個很水的dp,我都做不出來,有很多零星的想法,代碼寫不出來,真的會很失落,簡要講一下思路:
首先:確定dp[i][j]表示的含義,第i步時到達某點的最大方案數,
其次:找dp轉移方程,因為一個點有三種方式到達,所以要再加一重for回圈,

dp[i][j]+=dp[i-1][g]  (g表示從除自己所處點之外某個點,表示上一步g點的最大方案數)

雖然每次訓練賽因為各種原因都輸的很不甘心,但只有不斷的完善,找到隊伍的問題,總結自身的原因,不斷鞭策自己,不斷追趕別人,也還不錯,但說到底,沒有人愿意輸,相信一定會追上并超越,不用怕爬的慢,不為給他們看!!!

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/277173.html

標籤:其他

上一篇:谷歌聯網斷網都可以玩的恐龍小游戲(內容有不死加速掛)

下一篇:linux 學習記錄--目錄處理命令

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more