導航:首頁 > 源碼編譯 > 演算法題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相關的資料

熱點內容
夜蒲聚會app是什麼軟體 瀏覽:641
任天堂如何區分伺服器 瀏覽:818
雲伺服器的運用前景 瀏覽:547
解壓視頻素材哪裡有 瀏覽:255
小米5android7 瀏覽:842
極品飛車10修改直接解壓 瀏覽:640
簡易演算法怎麼用 瀏覽:497
壓縮比101用什麼油 瀏覽:562
買白銀下什麼APP 瀏覽:842
伺服器操作台如何操作 瀏覽:245
可編程安全繼電器 瀏覽:989
兔牙喵喵喵解壓文件密碼 瀏覽:277
磁碟新建文件夾未響應 瀏覽:997
有什麼錄音app帶混響 瀏覽:941
英語精讀pdf 瀏覽:207
戒煙之後排解壓力 瀏覽:908
視頻網站如何選伺服器 瀏覽:257
單片機中ramrom是什麼顏色 瀏覽:40
dev編譯完不顯示控制台窗口 瀏覽:595
程序員自學有希望嗎 瀏覽:528