teratail header banner
teratail header banner
質問するログイン新規登録

質問編集履歴

2

突っかかってくる方がいるのでそれを避けるために

2020/10/11 08:07

投稿

退会済みユーザー
title CHANGED
@@ -1,1 +1,1 @@
1
- C言語ループごとに初期値を+1
1
+ 解決済みの質問なので大丈夫で
body CHANGED
@@ -1,56 +1,1 @@
1
- 配列をn個入力して、その中で値の差の絶対値が一番小さい配列のペアとその絶対値を出力するプログラムを作ろうと考えています。
2
- のプログラムでは、総当たり配列差の絶対値計算し、中の最小値得ようとしていま
1
+ ポインタ使い方やループについて質問をしましたが予期せぬ指摘を受けたでコード削除させていただきした
3
- 1日考えましたが、どこが間違っているのか分かりませんでした。
4
- 入力を、
5
- 5
6
- -4
7
- 4.5
8
- -1.1
9
- 4.2
10
- 10.4
11
- とすると、実行結果が
12
- 最も近いペア:(a[0],a[3]), 距離:8.200000
13
- となります。fabsの使い方やポインタの使い方も曖昧なので、ご教授いただきたいです。
14
-
15
-
16
- ```C
17
- #include<stdio.h>
18
- #include<math.h>
19
-
20
- //aとbは配列番号の記憶、*kは最小距離,nは配列の要素数
21
- void cal(int* a, int* b, double* k, double *t, int n){
22
- int s = 1, count = 1;
23
- *k = fabs(t[0] - t[1]);
24
- for (int i=0; i < n - 1; i++) {
25
- for (s; s < n; s++) {
26
- if (fabs(t[i] - t[s]) < (*k)) {
27
- *k = fabs(t[i] - t[s]); //最小距離の記憶
28
- *a = i;
29
- *b = s;
30
- }
31
- count++;
32
- s = count;
33
- }
34
- }
35
- }
36
-
37
- int main(void) {
38
- int n;
39
- scanf("%d",&n);
40
- double a[n];
41
- for (int i = 0; i < n; i++) {
42
- scanf("%lf", &a[i]);
43
- }//ここまで配列の作成と入力
44
- int p1, p2;//最初距離のペアの配列番号を記憶する変数
45
- double min;//最小距離
46
- int* pair_1;
47
- int* pair_2;
48
- double* x_dst;
49
- pair_1 = &p1;
50
- pair_2 = &p2;
51
- x_dst = &min;
52
- cal(pair_1, pair_2, x_dst, a, n);
53
- printf("最も近いペア:(a[%d],a[%d]), 距離:%f", p1, p2, min);
54
- return 0;
55
- }
56
- ```

1

自分の実現したいことを加筆しました。

2020/10/11 08:07

投稿

退会済みユーザー
title CHANGED
File without changes
body CHANGED
@@ -1,4 +1,5 @@
1
1
  配列をn個入力して、その中で値の差の絶対値が一番小さい配列のペアとその絶対値を出力するプログラムを作ろうと考えています。
2
+ 下のプログラムでは、総当たりに配列の差の絶対値を計算し、その中の最小値を得ようとしています。
2
3
  1日考えましたが、どこが間違っているのか分かりませんでした。
3
4
  入力を、
4
5
  5
@@ -11,6 +12,7 @@
11
12
  最も近いペア:(a[0],a[3]), 距離:8.200000
12
13
  となります。fabsの使い方やポインタの使い方も曖昧なので、ご教授いただきたいです。
13
14
 
15
+
14
16
  ```C
15
17
  #include<stdio.h>
16
18
  #include<math.h>