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

熱點內容
硬碟格式化時用的dos命令是 瀏覽:938
找人緩解壓力 瀏覽:930
iphone的pdf 瀏覽:343
90壓縮餅干怎麼吃 瀏覽:661
php教材下載 瀏覽:906
什麼解壓密碼最好 瀏覽:583
資料庫與伺服器如何連接 瀏覽:436
架構師需要閱讀的源碼 瀏覽:476
ch編譯器 瀏覽:451
java必須自己寫一個編譯器嗎 瀏覽:939
如何製作androidrom 瀏覽:470
單片機萬能板怎麼寫入程序 瀏覽:21
邁銳寶xl壓縮比 瀏覽:341
靠演算法買彩票 瀏覽:498
程序員考核d 瀏覽:240
自助游中國pdf 瀏覽:747
安卓p40是什麼手機 瀏覽:87
24cxx編程器 瀏覽:591
陰陽師如何查看哪個伺服器有ID 瀏覽:316
公務員照片壓縮 瀏覽:459