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

This blog has been shut down permanently.

  C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  13 隨筆 :: 0 文章 :: 25 評(píng)論 :: 0 Trackbacks

最開(kāi)始用了很原始的數(shù)據(jù)初始化方法,多謝dskit指點(diǎn),現(xiàn)在已經(jīng)改正為哈希字典了。因?yàn)樵趧?chuàng)建新節(jié)點(diǎn)的時(shí)候浪費(fèi)時(shí)間比較嚴(yán)重,所以如果改成用向量會(huì)更好一些。

#include<stdio.h>
#include
<stdlib.h>
int map[25]= {2223334445556667077888999};
typedef 
struct LNode{
    
int data[8];
    
struct LNode *next;
}
;
int main()
{
    
int row,c,tag,i,j,n,temp[7];//輸入次數(shù)
    n=0;//電話(huà)號(hào)碼個(gè)數(shù)
    LNode *head=0//指向鏈表頭節(jié)點(diǎn)
    LNode *front= 0//指向當(dāng)前節(jié)點(diǎn)的前一位置
    LNode *tail= 0//指向當(dāng)前遍歷到的節(jié)點(diǎn)
    scanf("%d\n",&row);
    
if(row<=0&&row>100000return 0;
    
for(i=0; i<row; i++)//將有效輸入存入temp數(shù)組
    {
       
for(j=0; (c= getchar())&&(c!='\n')&&(j<7); )
       
{
           
if(c!='-')
           
{
               
if(c>='A'&&c<='Y')temp[j++]= map[c-'A'];
               
else if(c>='0'&&c<='9')temp[j++]= c-'0';
           }

       }

       
if(n==0//新建第一節(jié)點(diǎn)
       {
           LNode 
*p= (LNode *)malloc(sizeof(LNode));
           
for(int j=0; j<7; j++)
               p
->data[j]= temp[j];
           p
->data[7]= 1;
           p
->next= 0;
           head
= p;
           n
++;
           
continue;
       }

       
else //新建非第一節(jié)點(diǎn)
       {
           tag
= -1;
           
for(front= head,tail= head; tail!= 0; front= tail,tail= tail->next)
           
{
                
for(j=0; j<7; j++)
                
{
                    
if(tail->data[j]>temp[j])   //找到的目標(biāo)節(jié)點(diǎn)值大于temp
                    {
                        
if(front==tail){tag=2;break;}
                        
else {tag=3;break;}
                    }

                    
else if(tail->data[j]<temp[j])  //目標(biāo)節(jié)點(diǎn)值小于temp
                    {
                        
if(tail->next==0){tag= 0;break;}
                        
else break;
                    }

                    
else if(j==6&&tail->data[j]==temp[j]){tag=1;tail->data[7]+=1;break;} //目標(biāo)節(jié)點(diǎn)值等于temp
                }

                
if(tag==-1)continue;      //未找到插入點(diǎn)
                else if(tag==1)break;     //目標(biāo)節(jié)點(diǎn)值等于temp
                else if(tag==0)           //目標(biāo)節(jié)點(diǎn)值小于temp
                {
                    LNode 
*p= (LNode *)malloc(sizeof(LNode));
                    
for(j=0; j<7; j++)
                        p
->data[j]= temp[j];
                    p
->data[7]= 1;
                    p
->next= 0;
                    tail
->next= p;
                    n
++;
                    
break;
                }

                
else if(tag==2)   //找到的目標(biāo)節(jié)點(diǎn)值大于temp,目標(biāo)節(jié)點(diǎn)為頭結(jié)點(diǎn)
                {
                    LNode 
*p= (LNode *)malloc(sizeof(LNode));
                    
for(j=0; j<7; j++)
                        p
->data[j]= temp[j];
                    p
->data[7]= 1;
                    p
->next= head;
                    head
= p;
                    n
++;
                    
break;
                }

                
else if(tag==3)   //找到的目標(biāo)節(jié)點(diǎn)值大于temp,目標(biāo)節(jié)點(diǎn)非頭結(jié)點(diǎn)
                {
                    LNode 
*p= (LNode *)malloc(sizeof(LNode));
                    
for(j=0; j<7; j++)
                       p
->data[j]= temp[j];
                    p
->data[7]= 1;
                    p
->next= tail;
                    front
->next= p;
                    n
++;
                    
break;
                }

            }

        }

    }

    tag
= 0;
    
for(tail= head; tail!=0; tail= tail->next)    //遍歷鏈表輸出
    {
        
if(tail->data[7]>1)
        
{
            tag
= 1;
            
for(i=0; i<8; i++)
            
{
                
if(i==3)printf("-");
                
if(i==7)printf(" ");
                printf(
"%d",tail->data[i]);
            }

            printf(
"\n");
        }

    }

    
if(tag==0)printf("No duplicates.");
}
posted on 2009-11-11 00:44 iZ 閱讀(1911) 評(píng)論(4)  編輯 收藏 引用

評(píng)論

# re: POJ1002鏈表算法 2009-11-11 21:54 夢(mèng)芭莎
不錯(cuò),收藏一下算法,省得自己寫(xiě)  回復(fù)  更多評(píng)論
  

# re: POJ1002鏈表算法 2009-11-12 15:18 凡客誠(chéng)品官方網(wǎng)
收藏了!!  回復(fù)  更多評(píng)論
  

# re: POJ1002鏈表算法 2009-11-15 21:51 iSsay
其實(shí)可以?xún)?yōu)化的地方很多,就是不知道該怎么改了  回復(fù)  更多評(píng)論
  

# re: POJ1002鏈表算法[未登錄](méi) 2009-11-16 22:44 dskit
#include<iostream>
using std::cin;
using std::cout;
using std::endl;

#ifdef DEBUG
#include<string>
using std::string;
using std::freopen;
string input_file_name = __FILE__;
#endif

//here add other file need to included, and declare namespace need to use.
#include<stdlib.h>
#include<string.h>
#include<stdio.h>
using namespace std;
//here declare global variables;
char dictionary[26] = {2, 2, 2, 3, 3, 3, 4, 4, 4, 5, 5, 5, 6, 6, 6, 7, 0, 7, 7, 8, 8, 8, 9, 9, 9, 0};
char no[50];
char oarray[10];
bool flag;

struct Trie_node
{
int count;
Trie_node* next[10];
};

Trie_node root;

Trie_node node_pool[200002];
int index;
Trie_node* p;

void insert(char* s)
{
p = &root;
while(*s != '\0')
{
if(p->next[*s - '0'] == NULL)
p->next[*s - '0'] = &node_pool[index++];
p = p->next[*s - '0'];
++s;
}

++p->count;
}

void inline travel(Trie_node* node, int c)
{
for(int i = 0; i < 10; ++i)
{

if(node->next[i] == NULL)
continue;

oarray[c] = (char)(i + '0');

if(c >= 6)
{
if(node->next[i]->count > 1)
{
flag = true;
printf("%c%c%c-%c%c%c%c %d\n", oarray[0], oarray[1],
oarray[2], oarray[3],
oarray[4], oarray[5],
oarray[6], node->next[i]->count);
}
}
else
{
travel(node->next[i], c + 1);
}
}

}


//here add funtions.
void inline format_number(char* no)
{
//int len = strlen(no);
//printf("%s\n", no);
int count = 0;
int sum = 0;
for(int i = 0; no[i] != '\0'; ++i)
{
++sum;
if(no[i] >= 'A' && no[i] <= 'Z')
{
no[i] = '0' + dictionary[no[i] - 'A'];
}
else if(no[i] == '-')
{
++count;
}

if(no[i] != '-')
no[i - count] = no[i];

}
no[sum - count] = '\0';
//printf("%s\n", no);
}

int main(int argc, char* argv[])
{
#ifdef DEBUG
if(!freopen((input_file_name.substr(0, input_file_name.size() - 4) + ".in").c_str(), "r", stdin))
{ cout << "input data error, not found input file." << endl; return -1; }
#endif

//here add code for solve problem.
int n = 0;
//input
scanf("%d", &n);
flag = false;
index = 0;
getchar();
for(int i = 0; i < n; ++i)
{
gets(no);
//puts(no);
format_number(no);
insert(no);
}

travel(&root, 0);

if(!flag)
{
printf("No duplicates.\n");
}

return 0;
}
  回復(fù)  更多評(píng)論
  


只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲一级黄色av| 一区二区三区高清在线| 久久综合九色综合欧美狠狠| 欧美自拍偷拍| 久久亚洲综合色| 免费毛片一区二区三区久久久| 久热国产精品| 欧美黄色aaaa| 亚洲人成高清| 亚洲最新色图| 性欧美超级视频| 久久久爽爽爽美女图片| 免费一区视频| 欧美午夜激情视频| 国产精品私人影院| 黑人极品videos精品欧美裸| 韩国一区二区三区美女美女秀| 精久久久久久| 亚洲精品综合| 亚洲欧美色一区| 久久久综合激的五月天| 欧美护士18xxxxhd| 一区二区三区日韩欧美| 亚洲自拍偷拍一区| 久久综合九色欧美综合狠狠| 欧美成人国产一区二区| 国产精品v亚洲精品v日韩精品| 国产欧美日韩在线播放| 在线免费日韩片| 亚洲最新色图| 久久国产乱子精品免费女| 欧美va亚洲va香蕉在线| 亚洲精品一区二区三区樱花 | 亚洲欧美一区二区三区极速播放| 欧美一区二区三区免费观看| 久久另类ts人妖一区二区| 亚洲电影欧美电影有声小说| 亚洲最新视频在线| 久久久久久久欧美精品| 欧美日韩国产精品成人| 国产亚洲人成a一在线v站| 亚洲欧洲一区二区在线观看| 亚洲欧美精品suv| 免费观看一级特黄欧美大片| 在线亚洲电影| 久久综合给合久久狠狠狠97色69| 欧美日韩精品免费观看| 韩国精品在线观看| 亚洲午夜视频在线观看| 久久亚洲精品欧美| 一区二区三区四区国产精品| 久久久免费观看视频| 国产精品久久国产精麻豆99网站| 在线日韩视频| 久久激情五月丁香伊人| 亚洲精品一品区二品区三品区| 欧美一区二视频| 欧美日韩一区二区三区四区五区| 精品91久久久久| 性欧美1819性猛交| 亚洲人成网站在线观看播放| 欧美在线视频观看免费网站| 欧美日韩四区| 亚洲精品日韩久久| 久久亚洲影音av资源网| 亚洲一二三区在线| 欧美日本三区| 亚洲韩国日本中文字幕| 久久久91精品国产一区二区三区| 亚洲精品美女在线| 免费国产一区二区| 激情久久五月| 欧美中日韩免费视频| 一区二区三区四区国产| 欧美黄网免费在线观看| 亚洲福利视频网站| 久久久久久一区二区三区| 亚洲一区二区三区在线| 欧美色图一区二区三区| 亚洲卡通欧美制服中文| 欧美黄色日本| 久久久亚洲一区| 激情欧美一区二区三区| 久久亚洲不卡| 久久se精品一区精品二区| 国产精自产拍久久久久久| 亚洲欧美www| 一区二区三区四区在线| 国产精品av久久久久久麻豆网| 亚洲美女视频在线观看| 亚洲高清久久| 欧美精品久久一区二区| 99精品欧美一区二区三区| 亚洲国产免费看| 欧美高潮视频| 日韩亚洲不卡在线| 亚洲欧洲精品成人久久奇米网| 欧美91福利在线观看| 亚洲激情在线观看视频免费| 欧美成人免费观看| 免费不卡在线视频| 亚洲精品一区二区在线| 亚洲国产精品一区| 欧美精品手机在线| 一本色道久久综合亚洲精品按摩| 亚洲精品一线二线三线无人区| 欧美激情91| 亚洲一区二区在线| 亚洲欧美日韩一区二区三区在线| 国产精品视频男人的天堂| 欧美一区二区成人| 欧美影视一区| 亚洲国产美女精品久久久久∴| 亚洲高清免费在线| 欧美日本亚洲视频| 亚洲欧美日韩国产| 亚洲欧美美女| 在线观看不卡av| 最近中文字幕mv在线一区二区三区四区| 欧美黄色影院| 香蕉免费一区二区三区在线观看| 性久久久久久久久久久久| 伊人激情综合| 亚洲国产婷婷| 国产精品美女久久福利网站| 久久精品欧美日韩| 免费欧美视频| 亚洲女同性videos| 久久激情视频| 日韩一区二区精品葵司在线| 亚洲视频在线一区| 狠狠色丁香婷婷综合| 亚洲精品欧美极品| 国产精品资源在线观看| 久久久久久综合网天天| 男女视频一区二区| 香蕉久久夜色精品国产使用方法| 久久久精品国产免大香伊| 日韩视频国产视频| 午夜国产欧美理论在线播放| 在线观看日韩av电影| 一本色道久久综合亚洲精品小说| 国产视频在线一区二区 | 久久精品毛片| 欧美xx69| 久久国产视频网站| 欧美黑人在线观看| 久久久97精品| 欧美日韩一区二区三区视频| 久久视频免费观看| 欧美日韩第一区| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美日韩国产成人| 久久综合精品一区| 欧美午夜a级限制福利片| 噜噜爱69成人精品| 欧美午夜宅男影院| 欧美激情第三页| 国产欧美一区二区白浆黑人| 亚洲国产精品久久久| 国产主播精品| 中文亚洲免费| 亚洲美女尤物影院| 久久久青草青青国产亚洲免观| 亚洲直播在线一区| 欧美福利视频在线| 免费在线日韩av| 国产麻豆日韩| 日韩亚洲一区二区| 亚洲激情女人| 久久精品五月婷婷| 欧美在线短视频| 欧美日韩精品伦理作品在线免费观看| 毛片av中文字幕一区二区| 国产精品亚发布| 99这里只有久久精品视频| 91久久国产自产拍夜夜嗨| 欧美一区二区视频在线| 午夜视频久久久| 欧美日精品一区视频| 亚洲人成在线观看网站高清| 在线观看欧美激情| 欧美在线综合视频| 久久福利一区| 国产裸体写真av一区二区| 亚洲图片在线观看| 亚洲欧美国产另类| 欧美新色视频| 日韩视频免费观看高清完整版| 亚洲欧洲中文日韩久久av乱码| 久久久精品国产免大香伊| 久久精品99国产精品日本 | 亚洲免费观看| 亚洲精品免费在线| 美女主播一区| 欧美国产精品va在线观看| 在线观看国产精品网站| 午夜精品一区二区三区在线| 香蕉久久夜色精品国产使用方法| 国产精品乱码一区二三区小蝌蚪 |