導航:首頁 > 源碼編譯 > 演算法題wa

演算法題wa

發布時間:2024-09-16 19:13:44

Ⅰ 這道ACM為什麼我是WA。

你這個方法只是局部的兩個是最大字典序,當全部都這樣排好後不一定是最大序。用這樣的方法是錯的。如果是我,會用一個直接的深度優先搜索,然後中間要進行剪枝(不然會TEL的)。
如果例:
3
cc
cca
b
這里的正確答案是:ccccab
而你的答案是:ccaccb

Ⅱ 杭電ACM 1257 為什麼老是WA

這道題目是動態規劃哈,不是貪心,是求最長遞增子序列的.你可一直接網路一下 單調遞增子序列或者直接網路 HDU 1257 你這演算法肯定不對 所以錯了.

這道題要求最長遞增子序列的長度,用二分+DP可求的。

#include <iostream>

using namespace std;

int result[30005]; //用於保存最長遞增子序列

int bisearch(int a[],int lenth,int h) //二分查找插入的位子,如h存在,則返回原位置,既不做改變,否則返回比h大的位子
{
int i=0,j=lenth-1,mid;
while(i<=j)
{
mid=(i+j)/2;
if(a[mid]==h)
return mid;
if(a[mid]>h)
j=mid-1;
else
i=mid+1;
}
return i;
}

int main()
{
int n,h,lenth,pos;
while(scanf("%d",&n)!=EOF) //注意寫上EOF,否則超時
{
result[0]=30005; //初始化最大,第一次執行的是插入操作
lenth=1;
while(n--)
{
scanf("%d",&h);
if(h>result[lenth-1]) //如果h比排頭的大,則將h作為新的排頭,長度增加,注意是>不是>=,
//如果有=則表示非遞減序列,與題意不符
result[lenth++]=h;
else //否則進行插入操作,將比h大一點的數覆蓋,不影響結果
{
pos=bisearch(result,lenth,h);
result[pos]=h;
}
}
printf("%d\n",lenth);
}
return 0;
}

閱讀全文

與演算法題wa相關的資料

熱點內容
檢測溫濕度和二氧化碳的單片機 瀏覽:964
安卓手機雨滴怎麼隱藏 瀏覽:587
pdf文件轉換器word 瀏覽:987
vscodepython模塊方法 瀏覽:344
如何知道伺服器有什麼漏洞 瀏覽:902
java電商訂單支付源碼 瀏覽:102
android手機滑鼠 瀏覽:465
php支付項目經驗 瀏覽:929
中國人民銀行在哪裡下載app 瀏覽:560
松餅pdf 瀏覽:667
萌新如何獲得命令 瀏覽:138
java設計模式及代碼 瀏覽:7
命令恢復資料庫 瀏覽:192
linuxoracle11gr2 瀏覽:972
攜程APP簽到在哪裡 瀏覽:389
dwg解壓方法 瀏覽:422
雲伺服器數據溝通 瀏覽:849
android地圖定位源碼 瀏覽:632
鴻蒙系統如何解除app安裝限制 瀏覽:499
阿里雲伺服器應用鏡像選哪個 瀏覽:345