亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? main.java

?? puzzle program witch dfs bsf and a* algorithm
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
/* * To change this template, choose Tools | Templates * and open the template in the editor. */package puzzle;/**  * * @author Slayer86 *///import puzzle.Wezel;//import puzzle.Drzewo;import java.util.Random;import java.io.BufferedReader;import java.io.IOException;//import java.io.InputStream;import java.io.InputStreamReader;//import java.util.ArrayList;public class Main {    /**     * @param args the command line arguments     */    public static boolean[] stanHash = new boolean[1324234];        public static int hashF1(Wezel lisc)    {      int hash;      hash = lisc.stan[0][0]*100000000+lisc.stan[0][1]*10000000;      hash+= lisc.stan[0][2]*1000000+lisc.stan[1][0]*100000;      hash+= lisc.stan[1][1]*10000+lisc.stan[1][2]*1000;      hash+= lisc.stan[2][0]*100+lisc.stan[2][1]*10+lisc.stan[2][2];      return hash;    }        public static void WypiszPuzzle(Wezel wezel)    {        for (int i = 0; i < 3; i++)                {            for (int j = 0; j < 3; j++)                System.out.print("[" + wezel.stan[i][j] + "]");            System.out.print("\n");            }                    }        public static boolean Wygrana(Wezel wezel)    {        if (wezel.stan[0][0] == 1 &&            wezel.stan[0][1] == 2 &&            wezel.stan[0][2] == 3 &&            wezel.stan[1][0] == 4 &&            wezel.stan[1][1] == 5 &&            wezel.stan[1][2] == 6 &&            wezel.stan[2][0] == 7 &&            wezel.stan[2][1] == 8 && wezel.stan[2][2] == 0)            return true;        else            return false;    }    public static int licznik=0;    public static int zero[][]=new int[3][3];    public static int funOceniajaca1(Wezel temp)    {        int ocena=0;        for (int i=0; i<3; i++)            for (int j=0; j<3; j++)                if (temp.stan[i][j]!=zero[i][j])                    ocena++;	return ocena;    }    public static int funOceniajaca2(Wezel temp)    {        int ocena=0;        int w1=0,k1=0,w2=0,k2=0;        for (int l=1; l<9; l++)        {            for (int i=0; i<3; i++)                for (int j=0; j<3; j++)                {                    if (zero[i][j]==l)                    {                        w1=i;                        k1=j;                    }                    if (temp.stan[i][j]==l)                    {                        w2=i;                        k2=j;                    }                }            if (w1!=w2) ocena+=Math.abs(w1-w2);            if (k1!=k2) ocena+=Math.abs(k1-k2);        }        return ocena;    }    public static Wezel BudujDrzewo(Wezel wezel)    {        Drzewo tree=new Drzewo();        int x0=0;         int y0=0;        int hash=0;        //boolean jest;        tree.open.add(wezel);        while(!tree.open.isEmpty())        {            Wezel lisc=tree.open.get(0);            tree.open.remove(0);            tree.closed.add(lisc);            for (int i=0; i<3; i++)                for (int j=0; j<3; j++)                    if (lisc.stan[i][j] == 0)                    {                        x0 = i;                        y0 = j;                    }            if (x0 - 1 >= 0) //gora            {                //jest=false;                Wezel temp=new Wezel(lisc.stan);                int pom = temp.stan[x0][y0];                temp.stan[x0][y0] = temp.stan[x0 - 1][y0];                temp.stan[x0 - 1][y0] = pom;                                //ustalenie hash-u                hash = hashF1(temp);                                //sprawdzenie czy takiego sanu nie ma juz w drzewie, za pomoca tablicy hash-ow                //1324234 oraz 1324213 losowe liczby przeciwdzalajace temu zeby 2 stany nie mialy tego samego hash-u                if (stanHash[hash % 1324234] != true && stanHash[hash % 1324213] != true)                {                    stanHash[hash % 1324234] = true;                    stanHash[hash % 1324213] = true;                    temp.rodzic=lisc;                    lisc.gora=temp;                    tree.open.add(lisc.gora);                    //wezel=lisc;                    licznik+=1;                }                              }            if (x0 + 1 <= 2) //dol            {                //jest=false;                Wezel temp=new Wezel(lisc.stan);                int pom = temp.stan[x0][y0];                temp.stan[x0][y0] = temp.stan[x0 + 1][y0];                temp.stan[x0 + 1][y0] = pom;                                 //ustalenie hash-u                hash = hashF1(temp);                                //sprawdzenie czy takiego sanu nie ma juz w drzewie, za pomoca tablicy hash-ow                //1324234 oraz 1324213 losowe liczby przeciwdzalajace temu zeby 2 stany nie mialy tego samego hash-u                if (stanHash[hash % 1324234] != true && stanHash[hash % 1324213] != true)                {                    stanHash[hash % 1324234] = true;                    stanHash[hash % 1324213] = true;                    temp.rodzic=lisc;                    lisc.dol=temp;                    tree.open.add(lisc.dol);                    //wezel=lisc;                    licznik+=1;                }                             }            if (y0 - 1 >= 0) //lewo            {                //jest=false;                Wezel temp=new Wezel(lisc.stan);                int pom = temp.stan[x0][y0];                temp.stan[x0][y0] = temp.stan[x0][y0 - 1];                temp.stan[x0][y0 - 1] = pom;                                 //ustalenie hash-u                hash = hashF1(temp);                                //sprawdzenie czy takiego sanu nie ma juz w drzewie, za pomoca tablicy hash-ow                //1324234 oraz 1324213 losowe liczby przeciwdzalajace temu zeby 2 stany nie mialy tego samego hash-u                if (stanHash[hash % 1324234] != true && stanHash[hash % 1324213] != true)                {                    stanHash[hash % 1324234] = true;                    stanHash[hash % 1324213] = true;                    temp.rodzic=lisc;                    lisc.lewo=temp;                    tree.open.add(lisc.lewo);                    //wezel=lisc;                    licznik+=1;                }                             }            if (y0 + 1 <=2) //prawo            {                //jest=false;                Wezel temp=new Wezel(lisc.stan);                int pom = temp.stan[x0][y0];                temp.stan[x0][y0] = temp.stan[x0][y0 + 1];                temp.stan[x0][y0 + 1] = pom;                                 //ustalenie hash-u                hash = hashF1(temp);                                //sprawdzenie czy takiego sanu nie ma juz w drzewie, za pomoca tablicy hash-ow                //1324234 oraz 1324213 losowe liczby przeciwdzalajace temu zeby 2 stany nie mialy tego samego hash-u                if (stanHash[hash % 1324234] != true && stanHash[hash % 1324213] != true)                {                    stanHash[hash % 1324234] = true;                    stanHash[hash % 1324213] = true;                    temp.rodzic=lisc;                    lisc.prawo=temp;                    tree.open.add(lisc.prawo);                    //wezel=lisc;                    licznik+=1;                }                              }        }        return wezel;    }        public static Wezel metodaA(Wezel wezel, int funkcja)    {        Drzewo agwiazdka = new Drzewo();         agwiazdka.open.add(wezel);         Wezel wygrany=null;         Wezel min=null;         int indeks=0;         while(!agwiazdka.open.isEmpty())         {            //wszerz.closed.add(wszerz.open.get(1));            for( int i=0; i<agwiazdka.open.size(); i++ )            {                if(min == null)                 {                    min=agwiazdka.open.get(i);                     indeks=i;		}		if(min.ocena > agwiazdka.open.get(i).ocena)                 {                    min = agwiazdka.open.get(i);                    indeks=i;		}            }            agwiazdka.open.remove(indeks);            Wezel temp=min;            min = null;            if (Wygrana(temp))            {                                wygrany = temp;                break;            }              if (temp.dol != null)            {                if (funkcja==1)                    temp.dol.ocena=funOceniajaca1(temp.dol);                else                    temp.dol.ocena=funOceniajaca2(temp.dol);                agwiazdka.open.add(temp.dol);                agwiazdka.closed.add(temp.dol);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日本一区二区三区四区| 日韩欧美另类在线| 日韩欧美中文字幕一区| 一区二区三区在线观看网站| 成人18精品视频| 久久蜜桃av一区二区天堂| 日韩制服丝袜先锋影音| 91福利视频在线| 日本欧美一区二区三区| 欧美最猛性xxxxx直播| 亚洲一区二区欧美日韩| 色综合久久久久久久久久久| 亚洲精品高清在线| 欧美少妇bbb| 美女在线一区二区| www国产亚洲精品久久麻豆| 国产综合色视频| 中文字幕一区二区三| 精品视频资源站| 久久99在线观看| 国产精品免费看片| 欧美在线999| 国产在线精品一区二区不卡了| 亚洲色图制服诱惑| 91精品国产综合久久久久久| 91麻豆.com| 久久se精品一区二区| 亚洲综合精品久久| 亚洲黄色小视频| 欧美伊人久久大香线蕉综合69| 蜜桃视频在线观看一区二区| 日韩一区欧美一区| 日韩一区二区电影| 在线亚洲高清视频| 成人精品一区二区三区中文字幕| 日韩电影在线一区二区| 最好看的中文字幕久久| 精品成人一区二区三区四区| 欧美喷潮久久久xxxxx| 91免费视频大全| 99久久久国产精品| 国产麻豆精品theporn| 麻豆免费看一区二区三区| 亚洲1区2区3区视频| 亚洲另类一区二区| 自拍偷拍亚洲欧美日韩| 国产精品污网站| 国产精品天干天干在线综合| 国产日本欧洲亚洲| 国产日产精品1区| 日本一区二区高清| 国产欧美日韩久久| 中文字幕亚洲精品在线观看| 成人免费在线视频| 亚洲视频一二三| 伊人性伊人情综合网| 亚洲午夜精品网| 蜜臀99久久精品久久久久久软件| 日本伊人午夜精品| 九一久久久久久| 成人中文字幕电影| 一本久道久久综合中文字幕| 欧美日韩在线不卡| 久久香蕉国产线看观看99| 国产女主播一区| 成人午夜电影小说| 91在线精品一区二区三区| 色猫猫国产区一区二在线视频| 欧美亚州韩日在线看免费版国语版| 8x福利精品第一导航| 亚洲精品一区二区三区福利| 国产精品久久久久四虎| 亚洲大片精品永久免费| 国产精品亚洲视频| 欧美日韩aaa| 自拍偷在线精品自拍偷无码专区 | 国产成人自拍网| 91久久线看在观草草青青| 欧美精品日韩一区| 中文字幕一区av| 国产最新精品精品你懂的| 91久久国产最好的精华液| 精品国产凹凸成av人网站| 亚洲一区二区三区在线看| 99久久国产综合精品色伊| 久久久青草青青国产亚洲免观| 亚洲国产日韩一级| 91色porny蝌蚪| 中文av字幕一区| 国产suv精品一区二区6| 久久综合久久综合亚洲| 日本91福利区| 91精品国产欧美日韩| 亚洲一级在线观看| 91社区在线播放| 亚洲视频你懂的| 成人黄色小视频| 国产婷婷色一区二区三区在线| 九一九一国产精品| 久久久精品蜜桃| 99久久精品免费观看| 曰韩精品一区二区| 欧美色精品天天在线观看视频| 亚洲国产日产av| 日韩一区二区三区免费看 | 日韩免费高清电影| 国产大陆精品国产| 亚洲人成电影网站色mp4| 99久久久精品| 午夜成人在线视频| 日韩女同互慰一区二区| 国产成人免费视| 亚洲男人天堂一区| 欧美一区二区三区四区高清| 国产一区在线看| 亚洲一区二区三区四区在线免费观看| 欧美视频在线播放| 久久er99热精品一区二区| 日本一区二区视频在线| 欧美日韩中文国产| 激情五月激情综合网| 国产精品初高中害羞小美女文| 精品视频在线看| 国产精品99久久久久久久vr | 午夜不卡av在线| 国产亚洲美州欧州综合国| 欧美日韩一区二区不卡| 国产夫妻精品视频| 日韩成人一级大片| 亚洲欧洲日韩av| 亚洲精品一区二区三区蜜桃下载| 在线中文字幕不卡| 懂色av一区二区三区免费观看| 日韩高清不卡在线| 亚洲成a人片在线观看中文| 国产清纯美女被跳蛋高潮一区二区久久w| 色偷偷久久一区二区三区| 国产精品一区二区果冻传媒| 首页国产丝袜综合| 一区二区成人在线| 一区二区三区av电影| 亚洲人成网站在线| 国产精品久久午夜夜伦鲁鲁| 国产午夜亚洲精品不卡| 欧美大片拔萝卜| 欧美大胆人体bbbb| 欧美精品乱码久久久久久按摩| 色噜噜狠狠一区二区三区果冻| 9色porny自拍视频一区二区| 国产mv日韩mv欧美| 99久久777色| 91同城在线观看| 欧美日韩一区二区三区四区 | 中文字幕一区二区三区视频| 国产日韩欧美综合在线| www成人在线观看| 亚洲视频每日更新| 天堂一区二区在线| 免费一级片91| 成人黄色a**站在线观看| 99久久精品一区二区| 欧美日韩一区二区三区视频| 欧美大片拔萝卜| 国产精品久久久久三级| 亚洲乱码一区二区三区在线观看| 夜夜夜精品看看| 国内欧美视频一区二区 | 国产一区二区三区av电影| 成人av中文字幕| 3atv在线一区二区三区| 国产精品理论在线观看| 亚洲午夜电影在线| 成人sese在线| 日韩精品一区二区三区四区视频| 欧美激情在线一区二区三区| 日韩精品福利网| 色综合色狠狠综合色| 精品国产露脸精彩对白| 亚洲综合999| 99精品国产99久久久久久白柏| 91精品国产欧美日韩| 亚洲欧美日韩国产手机在线| 国内精品伊人久久久久影院对白| 精品视频一区三区九区| 亚洲品质自拍视频| 国产成人亚洲综合a∨猫咪| 日韩一卡二卡三卡国产欧美| 亚洲黄色在线视频| 99re这里只有精品首页| 中文字幕av一区二区三区高| 极品美女销魂一区二区三区| 7777精品伊人久久久大香线蕉 | 久久精品视频免费| 国产又黄又大久久| 欧美成人性战久久| 久久成人av少妇免费| 久久综合久色欧美综合狠狠| 九色综合国产一区二区三区| 2020日本不卡一区二区视频| 久久99精品久久久久久久久久久久|