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

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

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

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

Q&A

解決済

1回答

808閲覧

c言語の二次配列のを降順にするプログラムについて

onoharatakuhiro

総合スコア1

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

0グッド

0クリップ

投稿2020/07/20 02:01

前提・実現したいこと

ここに質問の内容を詳しく書いてください。
(例)c言語の二次配列のを降順にするプログラムについて
1行1列には身長、1行2列に体重が1000行あるファイル(txt)を読み込み、身長と体重をセットにして降順にするプログラムを作りたいのです(比較は身長のみ)今作ったものだと身長とまとめて1行1列になっています。どなたかプログラムの修正する場所を具体的に教えてもらえないでしょうか。よろしくお願いします。

170 59
168 62
150 53 ``````

ここに言語を入力 c言語
ここに言語を入力

コード

#include <stdio.h>int main(void)

{

int i,j,N;

float h[1000],temp;

for(i=0;scanf("%f",&h[i])!=EOF&&i<1000;i++)

N=i;

for(j=N-1;j>0;j--)

{

for(i=0;i<j;i++)

{

if(h[i]>h[i+1])

{

temp = h[i];

h[i] = h[i+1];

h[i+1] = temp;

}

}

}

for(i=0;i<N;i++)

{

printf("\n%6.1f",h[i]);

}

printf("\n");

return 0;

}

発生している問題・エラーメッセージ

エラーメッセージ

該当のソースコード

ソースコード

試したこと

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

c

1#include <stdio.h> 2 3int main(void) 4{ 5 FILE *fp; 6 int i, j, N; 7 double h[1000], k[1000], temp; 8 9 fp = fopen("data.txt", "r"); 10 if (fp == NULL) 11 { 12 printf("data is not found\n"); 13 return 1; 14 } 15 16 for(i = 0; fscanf(fp, "%f%f", &h[i], &k[i]) == 2 && i < 1000; i++) 17 N = i; 18 fclose(fp); 19 20 for (j = 0; j < N - 1; j++) 21 { 22 for (i = j + 1; i < N; i++) 23 { 24 if (h[i] > h[i + 1]) 25 { 26 temp = h[i]; 27 h[i] = h[i + 1]; 28 h[i+1] = temp; 29 30 temp = k[i]; 31 k[i] = k[i + 1]; 32 k[i+1] = temp; 33 } 34 } 35 } 36 37 fp = fopen("data.txt", "w"); 38 if (fp == NULL) 39 { 40 printf("cannot write data\n"); 41 return 2; 42 } 43 44 for (i = 0; i < N; i++) 45 { 46 printf("%f %f\n", h[i], k[i]); 47 } 48 fclose(fp); 49 50 return 0; 51}

投稿2020/07/20 09:59

katahiromz

総合スコア186

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問