青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-72  評論-126  文章-0  trackbacks-0
http://acm.tju.edu.cn/toj/showp3232.html
簡單題。。考慮全相等的特殊情況

http://acm.tju.edu.cn/toj/showp3233.html
看明白后也是簡單題。。。從左上搜,從右下搜,考慮重合的情況

http://acm.tju.edu.cn/toj/showp3234.html
簡單DP,比賽時候復制下標沒改。。。花了10分鐘才檢查出。。
先排序:然后按從小到大的順序進行DP,因為要嚴格遞增,所有一個數只能影響比他大的數。。。

http://acm.tju.edu.cn/toj/showp3235.html
遞推,公式很快就出來。就是要大數,惡心死了。。沒寫過模板,臨時寫了一個。。TLE了,暈。。優化了幾次后AC。。
      = a[i-1] (P)
a[i] = a[i-1]*2 (L)
      = a[i-1]*2 + cnt(R)
      = a[i-1]*5 + cnt(*)
cnt為3的(*出現的的次數)次方,即:一個*是3,3個*就是27.。

http://acm.tju.edu.cn/toj/showp3236.html
數獨,只能用交叉線,還要判斷有沒有出錯
我寫了一個小時,用位運算,寫的很飄逸
可惜在判斷error的時候沒有考慮完全,當時提交了3次WA。
今天早上稍微修改了下check的函數,就AC了。。。
唉。。要是當時這地方檢查出來多好。。。

獻上我的AC代碼

#include<stdio.h>
#include
<string>
#define inf 511                        //9個數字全滿
#include
<stdlib.h>
int num[27];                        //用27個數字記錄下全局:橫的9個,豎的9個,9個小九宮格
char map[10][10];
bool lowbit(int x) {
    
return (x&(x-1))==0;
}
bool add(int id,char ch)
{
    
int buf = 1<<(ch-'0'-1);        //讀入數據
    if(num[id] & buf)                //有重復
        return true;
    num[id] 
+= buf;
    
return false;
}
bool fun(int a,int b)
{
    
int ans;
    
int buf;
    
int x,y,i,j;
    ans 
= inf - (num[(a/3)*3 + (b/3+ 18]|num[a]|num[b+9]);//這格可以填的數
    for(i=0;i<3;i++)
        
for(j=0;j<3;j++)
        {
            
if(i==0 && j==0)
                
continue;
            x 
= a/3*3 + (a+i)%3;
            y 
= b/3*3 + (b+j)%3;
            
if(map[x][y]=='.')
            {
                buf 
= num[x] | num[y+9];                    //這格不能填的數
                ans &= buf;                                    //這個可以填的數
            }
        }
    
if(!ans)                                                //這格不能填
        return false;
    
if(lowbit(ans))                                            //能填唯一的一個
    {
        num[a] 
+= ans;                                        //更新全局num
        num[b+9+= ans;
        num[(a
/3)*3 + (b/3+ 18+= ans;
        buf 
= 0;
        
while(ans) {
            ans 
>>= 1;
            buf 
++;
        }
        map[a][b] 
= buf + '0';
        
return true;
    }
    
return false;
}
bool check(int a,int b)
{
    
int ans;
    
int buf;
    
int x,y,i,j;
    ans 
= inf - (num[(a/3)*3 + (b/3+ 18]|num[a]|num[b+9]);
    
for(i=0;i<3;i++)
        
for(j=0;j<3;j++)
        {
            
if(i==0 && j==0)
                
continue;
            x 
= a/3*3 + (a+i)%3;
            y 
= b/3*3 + (b+j)%3;
            
if(map[x][y]=='.')
            {
                buf 
= num[x] | num[y+9];
                ans 
&= buf;
            }
        }
    
if(!ans || !lowbit(ans))
        
return false;
    
if(ans == 1<<(map[a][b] - '1'))
        
return false;
    
return true;                            //只能填一個且和這格數字不相等,則有沖突
}
int main()
{
    
int i,j;
    
bool flag;
    
while(scanf("%s",map[0])==1)
    {
        
for(i=1;i<9;i++)
            scanf(
"%s",map[i]);
        memset(num,
0,sizeof(num));
        
for(i=0;i<9;i++)
        {
            
for(j=0;j<9;j++)
            {
                
if(map[i][j]!='.')
                {
                    
if(add(i,map[i][j]))            //可以判斷有沒有重復的數字
                        goto loop;                    //適當的用下goto還是很好用的^-^
                    if(add(j+9,map[i][j]))
                        
goto loop;
                    
if(add((i/3)*3 + (j/3+ 18,map[i][j]))
                        
goto loop;
                }
            }
        }
        flag 
= true;
        
while(flag)
        {
            flag 
= false;
            
for(i=0;i<9;i++)
            {
                
for(j=0;j<9;j++)
                {
                    
if(map[i][j]=='.' && fun(i,j))
                        flag 
= true;
                    
else if(map[i][j]!='.' && check(i,j))
                        
goto loop;
                }
            }
        }
        
for(i=0;i<9;i++)
            puts(map[i]);
        
continue;
loop:
        puts(
"ERROR");
    }
    
return 0;
}
posted on 2009-04-05 11:16 shǎ崽 閱讀(356) 評論(1)  編輯 收藏 引用

評論:
# re: 第一輪PK。。。 2009-04-05 21:46 | AekdyCoin
太神牛了
仰慕0rz  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久精品国产99| 欧美一区二区三区四区夜夜大片| 久久视频在线看| 国产综合自拍| 欧美成人有码| 国产精品人人做人人爽| 亚洲欧美制服中文字幕| 久久久久久日产精品| 亚洲一区二区三区免费在线观看| 欧美国产精品人人做人人爱| 欧美中文字幕第一页| 亚洲欧美国产高清va在线播| 国产婷婷一区二区| 99国产精品99久久久久久| 狠狠入ady亚洲精品| 亚洲视频www| 亚洲美女av黄| 欧美成人精品三级在线观看| 久久精品视频免费播放| 宅男精品导航| 在线观看亚洲| 久久成人精品电影| 亚洲一区二区三区欧美| 国产精品男女猛烈高潮激情 | 欧美一区二区在线视频| 欧美国产精品劲爆| 亚洲欧洲三级电影| 国产综合色一区二区三区 | 好看的av在线不卡观看| 久久久青草婷婷精品综合日韩| 欧美在线999| 国产一级精品aaaaa看| 欧美在线视频网站| 亚洲国产精品va在线看黑人 | 蜜桃av一区| 999在线观看精品免费不卡网站| 18成人免费观看视频| 欧美日韩精品一区二区在线播放 | 亚洲国产精品久久久| 欧美视频网址| 美女主播一区| 亚洲影院在线观看| 久久综合伊人77777麻豆| 在线视频欧美精品| 欧美一区二视频| 亚洲激情在线视频| 免费亚洲电影在线| 久久永久免费| 欧美一区深夜视频| 午夜精品一区二区三区在线 | 欧美第一黄网免费网站| 久久aⅴ国产欧美74aaa| 99re热精品| 一区二区三区高清| 99国产精品久久久久久久成人热 | 亚洲综合首页| 亚洲欧洲av一区二区三区久久| 亚洲电影视频在线| 亚洲日本中文字幕区| 欧美大片一区二区三区| 欧美成人国产一区二区| 另类人畜视频在线| 亚洲国产精品激情在线观看| 亚洲国产精品电影| 欧美激情一区二区三区高清视频| 久久xxxx| 免费在线亚洲欧美| 日韩视频免费在线观看| 在线亚洲免费| 久久精品国产视频| 美女诱惑一区| 国产精品免费区二区三区观看| 国产精品护士白丝一区av| 午夜在线一区| 欧美国产精品人人做人人爱| 欧美亚洲成人免费| 亚洲国产91色在线| 一本色道久久加勒比88综合 | 一区二区三区日韩欧美| 欧美一区二区三区的| 欧美日韩视频一区二区三区| 国产精品日韩欧美一区二区| 在线精品视频免费观看| 亚洲视频在线观看三级| 免费观看一区| 久久精品成人欧美大片古装| 欧美精品久久一区二区| 含羞草久久爱69一区| 亚洲欧美日韩天堂| 一区二区三区欧美日韩| 欧美揉bbbbb揉bbbbb| 一区二区电影免费观看| 麻豆成人在线| 久久精品人人做人人综合| 欧美亚男人的天堂| 亚洲自拍偷拍视频| 99精品久久久| 国产精品夜夜夜| 欧美一区三区三区高中清蜜桃| 亚洲精品一区二区三区av| 欧美大秀在线观看| 一本色道久久综合亚洲精品婷婷| 老司机亚洲精品| 免费在线一区二区| 亚洲国产精品一区| 亚洲人体影院| 欧美日韩另类视频| 老鸭窝毛片一区二区三区| 欧美一级视频| 亚洲激情另类| 亚洲欧美日韩一区二区在线| 韩日欧美一区二区| 亚洲天堂av在线免费| 在线成人激情| 亚洲欧美在线免费| 亚洲欧洲精品一区二区三区 | 国产精品区一区二区三| 久久午夜精品| 欧美三级黄美女| 欧美国产日韩一区| 国产在线一区二区三区四区| 亚洲最新色图| 亚洲精品美女久久久久| 欧美一区二区日韩| 午夜精品久久久久久久久久久久久 | 久久狠狠亚洲综合| 亚洲美女网站| 久久综合久久综合久久| av成人免费| 欧美丰满高潮xxxx喷水动漫| 欧美专区日韩视频| 国产日韩欧美高清免费| 一区二区三区欧美视频| 日韩午夜电影| 欧美黄色大片网站| 国产丝袜一区二区| 午夜久久福利| 欧美成人激情视频| 亚洲动漫精品| 欧美精品1区| 亚洲视频在线观看视频| 欧美亚洲视频| 黑人极品videos精品欧美裸| 久久精品二区| 亚洲精品午夜精品| 久久一二三四| 亚洲一区二区在线观看视频| 国产欧美一区二区三区在线看蜜臀 | 在线观看一区视频| 欧美 亚欧 日韩视频在线| 一区二区久久久久久| 欧美jjzz| 久久精品一区二区三区中文字幕| 狠狠噜噜久久| 国产精品人人做人人爽| 欧美破处大片在线视频| 久久久免费精品视频| 一本综合久久| 久热精品视频在线| 欧美一区高清| 六十路精品视频| 久久这里有精品15一区二区三区| 久久se精品一区二区| 在线观看三级视频欧美| 国产精品国产三级国产普通话蜜臀| 一区二区三区国产在线观看| 久久久精品性| 亚洲综合色婷婷| 欧美一区二区在线| 亚洲第一中文字幕| 午夜久久一区| 亚洲一区二区av电影| 欧美无乱码久久久免费午夜一区| 亚洲午夜视频| 久久综合伊人77777| 美女久久一区| 久久久久久久久久久成人| 亚洲男人第一网站| 中日韩美女免费视频网址在线观看| 国产精品一区二区三区观看| 欧美fxxxxxx另类| 免费一区二区三区| 久久精品主播| 嫩草成人www欧美| 亚洲欧美日韩中文播放| 亚洲综合国产激情另类一区| 91久久视频| 一区二区三区视频免费在线观看| 欧美本精品男人aⅴ天堂| 欧美v国产在线一区二区三区| 亚洲香蕉网站| 久久久久综合网| 欧美激情精品久久久久久| 久久综合狠狠综合久久综青草| 亚洲高清视频一区| 国产日韩av在线播放| 亚洲一区网站| 美女国产精品| 亚洲天堂av图片| 欧美经典一区二区|