麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

情人碰面的問題:JAVA代碼概述

2019-11-18 13:09:43
字體:
來源:轉載
供稿:網友

  /*
  * 8情人問題:
  *
  * 問題描述:
  * 在一個8×8的棋盤里放置8個情人,要求每個情人兩兩之間不相沖突
  *(在每一橫列,豎列,斜列只有一個情人)。
  *
  * 數據表示:
  * 用一個 8 位的 8 進制數表示棋盤上情人的位置:
  * 比如:45615353 表示:
  *    第0列情人在第4個位置
  *    第1列情人在第5個位置
  *    第2列情人在第6個位置
  *    。。。
  *    第7列情人在第3個位置
  *
  * 循環變量從 00000000 加到 77777777 (8進制數)的過程,就遍歷了情人所有的情況
  * 程序中用八進制數用一個一維數組 data[] 表示
  *
  * 檢測沖突:
  *   橫列沖突:data[i] == data[j]
  *   斜列沖突:(data[i]+i) == (data[j]+j) 或者 (data[i]-i) == (data[j]-j)
  *
  * 好處:
  * 采用循環,而不是遞規,系統資源占有少
  * 可計算 n 情人問題
  * 把問題線性化處理,可以把問題分塊,在分布式環境下用多臺計算機一起算。
  *
  * ToDo:
  *  枚舉部分還可以進行優化,多加些判定條件速度可以更快。
  *  輸出部分可以修改成棋盤形式的輸出
  *
  * @author cinc 2002-09-11
  *
  */
  
  public class Queen {
  int size;
  int resultCount;
  
  public void compute ( int size ) {
  this.size = size;
  resultCount = 0;
  int data[] = new int[size];
  int count; // 所有可能的情況個數
  int i,j;
  
  // 計算所有可能的情況的個數
  count = 1;
  for ( i=0 ; i<size ; i++ ) {
  count = count * size;
  }
  // 對每一個可能的情況
  for ( i=0 ; i<count ; i++ ) {
  // 計算這種情況下的棋盤上情人的擺放位置,用 8 進制數表示
  // 此處可優化
  int temp = i;
  for ( j=0 ; j<size ; j++ ) {
  data [j] = temp % size;
  temp = temp / size;
  }
  // 測試這種情況是否可行,假如可以,輸出
  if ( test(data) )
  output( data );
  }
  }
  
  /*
  * 測試這種情況情人的排列是否可行
  *
  */
  public boolean test( int[] data ) {
  int i,j;
  for ( i=0 ; i<size ; i++ ) {
  for ( j=i+1 ; j<size ; j++ ) {
  // 測試是否在同一排
  if ( data[i] == data[j])
  return false;
  // 測試是否在一斜線
  if ( (data[i]+i) == (data[j]+j) )
  return false;
  // 測試是否在一反斜線
  if ( (data[i]-i) == (data[j]-j) )
  return false;
  }
  }
  return true;
  }
  
  /*
  * 輸出某種情況下情人的坐標
  *
  */
  public void output ( int[] data ){
  int i;
  System.out.PRint ( ++resultCount + ": " );
  for ( i=0 ; i<size ; i++ ) {
  System.out.print ( "(" + i + "," + data[i] + " " );
  }
  System.out.println ();
  }
  
  //main()就是在這里.
  public static void main(String args[]) {
  (new Queen()).compute( 8 );
  }
  }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 色屁屁xxxxⅹ免费视频 | 久久久经典视频 | 精品一区二区久久久久久按摩 | 中文字幕 在线观看 | 黄色网址你懂的 | 欧美成人高清视频 | 中文字幕精品在线视频 | 成人性视频欧美一区二区三区 | 欧美黄色一级带 | 一级片999 | 极色品影院 | 伊人999 | 九一国产精品 | 亚洲一区在线免费视频 | 性爱免费在线视频 | 免费嗨片首页中文字幕 | 男女羞羞视频在线免费观看 | 免费人成在线播放 | www.热| 亚洲第一色片 | 在线观看中文字幕国产 | 牛牛a级毛片在线播放 | 国产亚洲精品久久777777 | 亚洲网站一区 | 久久2019中文字幕 | 欧洲精品久久 | 国产噜噜噜噜久久久久久久久 | 在线成人www免费观看视频 | 亚洲午夜久久久久 | 欧美a视频 | 黄色毛片视频在线观看 | 伊人99re| 91香蕉国产亚洲一区二区三区 | 欧美3p激情一区二区三区猛视频 | av国产免费| 久久不射电影 | 国产99精品 | 成人福利视频在线 | av电影在线网站 | 香蕉秀 | 日韩av手机在线免费观看 |