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

熱點內容
電視命令行 瀏覽:323
情侶頭像醫生和程序員 瀏覽:433
被加密的光碟系統無法讀取 瀏覽:326
鬼泣巔峰之戰怎麼選擇推薦伺服器 瀏覽:737
ghostlinux下載 瀏覽:380
加密貨幣三大交易未來發展潛力 瀏覽:629
樹洞app怎麼看誰關注我 瀏覽:322
aapt編譯某一個xml 瀏覽:470
解壓助眠視頻外國 瀏覽:905
程序員女朋友照片當壁紙 瀏覽:747
oracle備份壓縮文件 瀏覽:134
雲伺服器攝像頭一定要wifi嗎 瀏覽:884
python編寫加減乘車程序 瀏覽:699
python離線安裝numpy 瀏覽:709
xplore解壓軟體怎麼設置 瀏覽:990
ios反編譯混淆代碼查看 瀏覽:315
雲計算優化演算法 瀏覽:422
手機頭條安裝文件夾 瀏覽:580
網吧伺服器怎麼分配機子 瀏覽:826
什麼是反編譯程序器 瀏覽:32