亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
国产精品美女久久久久aⅴ国产馆| 欧美日韩视频在线第一区| 精品久久久久久久一区二区蜜臀| 亚洲图片欧美综合| 欧美日韩一区二区电影| 视频一区视频二区中文字幕| 欧美日本精品一区二区三区| 久久精品国产亚洲aⅴ| 337p日本欧洲亚洲大胆精品| 成人激情午夜影院| 一区二区三区 在线观看视频| 91福利区一区二区三区| 日本午夜精品一区二区三区电影| 精品国产制服丝袜高跟| av亚洲精华国产精华| 美日韩一区二区| 日韩一区二区三区三四区视频在线观看 | 亚洲男人天堂av网| 欧美日韩在线直播| 国产综合色精品一区二区三区| 日本一区二区三区dvd视频在线| 成人网在线免费视频| 亚洲一区二区三区美女| 欧美大片拔萝卜| www.一区二区| 免播放器亚洲一区| 国产女主播视频一区二区| 在线中文字幕一区二区| 久久99久久99小草精品免视看| 国产精品乱码妇女bbbb| 欧美视频一区二区三区在线观看 | 国产精品嫩草影院av蜜臀| 91福利视频在线| 国产一区二三区| 综合电影一区二区三区 | 日韩欧美在线一区二区三区| 国产剧情在线观看一区二区| 亚洲精品美国一| 久久人人超碰精品| 91成人网在线| 国产成人av资源| 日韩激情中文字幕| 成人免费在线观看入口| 精品久久久久久最新网址| 在线一区二区三区四区五区| 国产91对白在线观看九色| 日韩成人免费电影| 亚洲影视在线播放| 国产精品入口麻豆原神| 欧美一区二区福利在线| 欧美综合久久久| 成人高清在线视频| 国产在线一区观看| 免费久久99精品国产| 亚洲一区二区美女| 亚洲欧洲av一区二区三区久久| 精品少妇一区二区三区视频免付费| 色94色欧美sute亚洲13| 9l国产精品久久久久麻豆| 久久国产精品第一页| 午夜国产精品一区| 一区二区三区免费| 亚洲欧美日韩一区| 国产精品久久毛片a| 久久精品免费在线观看| 精品国产一区二区三区四区四| 欧美精选一区二区| 欧美性猛交xxxxxxxx| 在线观看免费亚洲| 在线一区二区视频| 欧洲亚洲国产日韩| 欧洲视频一区二区| 在线观看av不卡| 色婷婷精品大视频在线蜜桃视频| 成人av在线资源网| 成人激情av网| 91视频一区二区三区| 91麻豆6部合集magnet| 91欧美一区二区| 色菇凉天天综合网| 在线视频国内一区二区| 欧美视频日韩视频在线观看| 欧美曰成人黄网| 欧美视频一区二区在线观看| 欧美日韩国产综合久久| 欧美一区二区三区在线观看视频| 91精品国产综合久久精品性色| 91精品在线观看入口| 日韩欧美一二区| 久久精品亚洲精品国产欧美 | 高清av一区二区| 粉嫩绯色av一区二区在线观看| 高清在线不卡av| 不卡一卡二卡三乱码免费网站| 成人小视频免费在线观看| 成人免费视频国产在线观看| 99精品视频中文字幕| 欧美视频第二页| 欧美成va人片在线观看| 久久婷婷综合激情| 自拍偷自拍亚洲精品播放| 亚洲成人动漫在线观看| 精品在线观看免费| 成人av在线网站| 欧美日韩午夜在线| 日韩精品一区二区三区视频 | 日本一区二区免费在线| 亚洲欧美日韩国产综合在线| 天堂蜜桃一区二区三区| 国产一区二区三区蝌蚪| 色屁屁一区二区| 欧美一区2区视频在线观看| 国产欧美综合色| 一区二区三区四区视频精品免费| 日韩黄色片在线观看| 国产成人免费高清| 欧美日本韩国一区二区三区视频| 精品欧美一区二区三区精品久久 | 一区二区三区中文免费| 日本成人在线不卡视频| 成人h动漫精品| 欧美另类高清zo欧美| 国产蜜臀97一区二区三区| 亚洲va中文字幕| 成人动漫中文字幕| 7777精品伊人久久久大香线蕉的| 中文字幕久久午夜不卡| 天堂一区二区在线免费观看| 成人污视频在线观看| 欧美一区二区高清| 一区二区高清视频在线观看| 国产一区激情在线| 91精品国产综合久久久久久漫画| 亚洲三级视频在线观看| 精彩视频一区二区| 精品污污网站免费看| 中文字幕日韩一区| 国产乱码精品一品二品| 欧美日韩国产一级片| 中文字幕在线不卡| 国产91精品免费| 久久一夜天堂av一区二区三区| 亚洲国产日日夜夜| 一本到不卡免费一区二区| 久久久精品国产免大香伊| 日韩精品亚洲专区| 在线观看三级视频欧美| 综合精品久久久| heyzo一本久久综合| 国产午夜精品在线观看| 黑人精品欧美一区二区蜜桃| 欧美日本精品一区二区三区| 亚洲综合丝袜美腿| 色婷婷一区二区| 亚洲嫩草精品久久| 91网站视频在线观看| 亚洲欧洲性图库| 国产成人av影院| 国产视频911| 国产成人亚洲综合a∨婷婷| 日韩你懂的在线播放| 日韩成人av影视| 欧美一区二区三区四区视频| 日韩激情av在线| 欧美一区二区视频在线观看2022| 五月婷婷激情综合| 欧美日韩中文字幕一区| 亚洲电影一级片| 欧美精选在线播放| 日韩成人伦理电影在线观看| 欧美日韩国产高清一区| 天天操天天综合网| 欧美一级在线视频| 久久99久久久欧美国产| 91精品国产综合久久久久| 捆绑变态av一区二区三区| 日韩欧美你懂的| 国产在线播放一区二区三区| 久久久久亚洲蜜桃| 99麻豆久久久国产精品免费| 日韩一区中文字幕| 欧美性生交片4| 免费观看在线色综合| 久久香蕉国产线看观看99| 国产成人精品综合在线观看| 亚洲丝袜另类动漫二区| 欧美日韩免费不卡视频一区二区三区| 日韩影视精彩在线| 久久久久久久久久看片| 99久久99久久久精品齐齐| 一二三区精品视频| 日韩欧美国产不卡| 国产福利91精品一区| 亚洲精品你懂的| 日韩精品一区二区三区蜜臀| 不卡的av在线| 日韩1区2区3区| 欧美激情一区二区在线| 欧美中文字幕不卡| 狠狠色丁香婷婷综合|