質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
JavaFX

JavaFXとは、Java仮想マシン上で動作するリッチインターネットアプリケーション (RIA) のGUIライブラリです。Swingとは異なり、FXMLと呼ばれる XMLとCSSを併用してデザインを記述します。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

1回答

1849閲覧

Java 数独 消去法

purogutamu

総合スコア17

JavaFX

JavaFXとは、Java仮想マシン上で動作するリッチインターネットアプリケーション (RIA) のGUIライブラリです。Swingとは異なり、FXMLと呼ばれる XMLとCSSを併用してデザインを記述します。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2020/12/02 07:48

前提・実現したいこと

今、javaでナンプレ(数独)を解くプログラムを作っています。バックトラッキングなどの方法で解くことはできます。そこで、別の方法で解いてみたいなと考え、消去法で解くようなプログラムを作りました。

(消去法)
一つのセルに対し、3×3のブロック、行、列の数字を確認し、8種類の値があれば残りの一種類を代入する。

この方法だけ解くと、数独で解ける問題と解けない問題が存在することがわかりました。むしろ解けない問題の方が多かったです。作る前はこの方法で解ける!と思っていたのですが、考えてみれば解けないやつもある。。。。
そこで、主軸は消去法で、他の方法(バックトラッキング以外)を追加して、解く方法(アルゴリズム)を教えてください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

shiketa

2020/12/04 03:14

> 解く方法(アルゴリズム)を教えてください。 そこを考えるから、プログラミングって愉しいんじゃないですか。一番の醍醐味を捨てるなんて勿体無い。
guest

回答1

0

ベストアンサー

お疲れ様です。

私も紙とペンの補助として、Excelを使いながら消去法でチャレンジしてみても、ある程度難しいものは消去法だけでは解けません。

その升に入力できる値を仮においてみるということが必要になります。
将棋のように相当先まで読む力があれば解くことができると思いますが、私には無理です。

数独の解き方というサイトがいろいろありますので、参考にするとよいと思います。
最終的には消去法で解けないものは、力技(バックトラッキング法など)かなと思います。

投稿2020/12/03 03:04

senior_golfer

総合スコア264

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

purogutamu

2020/12/03 09:08

なるほど仮置きでやってみます。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問