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

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

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

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

Q&A

解決済

3回答

3050閲覧

javaでデータを読み込んでソートしたいのですがうまく来ません

TakaoHayashi

総合スコア7

Java

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

0グッド

0クリップ

投稿2016/07/08 09:51

コンパイルするとエラーになって
「シンボルが見つかりません」と表示されます。

他にも問題があれば教えてください

java

1import java.io.File; 2import java.io.FileReader; 3import java.io.FileNotFoundException; 4import java.io.IOException; 5 6public class SortTest{ 7 8 public static void main(String args[]){ 9 int deta_num=10; 10 int n[] =new int[deta_num]; 11 12 try{ 13 File file = new File("/Users/ruth/Desktop/Test.txt"); 14 FileReader filereader = new FileReader(file); 15 16 int str = Integer.parseInt(br.readline()); 17 int count =1; 18 19 int ch; 20 while((ch = filereader.read()) != -1){ 21 n[count]=str; 22 str = Integer.parseInt(br.readline()); 23 24 } 25 filereader.close(); 26 QuickSortTest quick_sort= new QuickSortTest(); 27 quick_sort.sort(n); 28 29 30 31 32 33 }catch(FileNotFoundException e){ 34 System.out.println(e); 35 }catch(IOException e){ 36 System.out.println(e); 37 } 38 } 39} 40class QuickSortTest { 41 // 配列dのleftからrightまでの間のデータ列をクイックソートする 42 static void quick_sort(int[] d, int left, int right) { 43 if (left>=right) { 44 return; 45 } 46 int p = d[(left+right)/2]; 47 int l = left, r = right, tmp; 48 while(l<=r) { 49 while(d[l] < p) { l++; } 50 while(d[r] > p) { r--; } 51 if (l<=r) { 52 tmp = d[l]; d[l] = d[r]; d[r] = tmp; 53 l++; r--; 54 } 55 } 56 quick_sort(d, left, r); // ピボットより左側をクイックソート 57 quick_sort(d, l, right); // ピボットより右側をクイックソート 58 } 59 // 配列内のデータ列を表示する 60 static void print_data(int[] d) { 61 for(int i = 0; i < d.length; i++) System.out.print(d[i] + " "); 62 System.out.println(); 63 } 64 public void Sort(int[] args) { 65 //関数の呼び出しする 66 67 print_data(data); 68 quick_sort(deta, 0, deta.length-1); 69 print_data(deta); 70} 71 72 } 73

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

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

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

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

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

tamy

2016/07/08 10:12

エラーの内容をもう少し詳しく書けませんか?(何行目でエラーが出るとか) ちなみに,メソッド名は大文字(Sort)なのに,呼び出し時は小文字(quick_sort.sort)になっている部分を直してもエラー出ますか?
guest

回答3

0

コンパイルエラーをとってみました。
ファイルを 1行ずつ読むようにしてみました。
ソート処理は変更していません。

java

1import java.io.BufferedReader; 2import java.io.FileNotFoundException; 3import java.io.FileReader; 4import java.io.IOException; 5 6//See http://www.javadrive.jp/start/stream/index3.html 7//まとめてテキストを読む 8 9public class SortTest { 10 11 public static void main(String args[]) { 12 final String FILE_NAME = "test.txt"; // "/Users/ruth/Desktop/Test.txt"; 13 final int DATA_NUM = 10; 14 int n[] = new int[DATA_NUM]; 15 BufferedReader br = null; 16 17 try { 18 String line; 19 int count = 0; 20 21 br = new BufferedReader(new FileReader(FILE_NAME)); 22 while ((line = br.readLine()) != null) { 23 n[count] = Integer.parseInt(line); 24 count++; 25 if (DATA_NUM <= count) { 26 break; 27 } 28 } 29 QuickSortTest quick_sort = new QuickSortTest(); 30 quick_sort.sort(n); 31 32 } catch (FileNotFoundException e) { 33 System.out.println(e); 34 } catch (IOException e) { 35 System.out.println(e); 36 } finally { 37 if (br != null) { 38 try { 39 br.close(); 40 } catch (IOException e) { 41 e.printStackTrace(); 42 } 43 } 44 } 45 } 46} 47 48class QuickSortTest { 49 // 配列dのleftからrightまでの間のデータ列をクイックソートする 50 static void quick_sort(int[] d, int left, int right) { 51 if (left >= right) { 52 return; 53 } 54 int p = d[(left + right) / 2]; 55 int l = left, r = right, tmp; 56 while (l <= r) { 57 while (d[l] < p) { 58 l++; 59 } 60 while (d[r] > p) { 61 r--; 62 } 63 if (l <= r) { 64 tmp = d[l]; 65 d[l] = d[r]; 66 d[r] = tmp; 67 l++; 68 r--; 69 } 70 } 71 quick_sort(d, left, r); // ピボットより左側をクイックソート 72 quick_sort(d, l, right); // ピボットより右側をクイックソート 73 } 74 75 // 配列内のデータ列を表示する 76 static void print_data(int[] d) { 77 for (int i = 0; i < d.length; i++) { 78 System.out.print(d[i] + " "); 79 } 80 System.out.println(); 81 } 82 83 public void sort(int[] data) { 84 // 関数の呼び出しする 85 print_data(data); 86 quick_sort(data, 0, data.length - 1); 87 print_data(data); 88 } 89 90}

投稿2016/07/09 00:08

katoy

総合スコア22324

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

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

0

SortTestクラスにて、コンパイルエラーが発生する理由ですが、

java

1FileReader filereader = new FileReader(file); 2 3int str = Integer.parseInt(br.readline());

br が特に何も宣言せず使われているためエラーとなります。
brの名前から察するに BufferedReaderでしょうか。

java

1FileReader filereader = new FileReader(file); 2BufferedReader br = new BufferedReader(filereader); 3int str = Integer.parseInt(br.readLine());

投稿2016/07/08 13:57

A-pZ

総合スコア12011

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

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

0

ベストアンサー

提示されているコードにSortメソッドは存在しますが、sortメソッドは存在しませんね。

エラーについて質問する時は内容を端折らずにしっかりと書きましょうね。

投稿2016/07/08 11:53

yona

総合スコア18155

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問