0

Q1、Q2、および Q3 を検索するために次のコードを使用しています (期待どおりに動作します) が、set_qrt()のみを使用intして書き込み%、位置を検索することはできません

四分位数はQ1 = 1.51.0, 2.0, 3.0なければなりません。Q2 = 2.0; Q3 = 2.5

四分位数はQ1 = 2.01.0, 2.0, 3.0, 4.0, 5.0, 6.0なければなりません。Q2 = 3.5; Q3 = 5.0

#include <stdio.h>
#include <stdlib.h>

typedef struct {
    double qrt[3];
    double *value;
    int count;
} t_data;

static void set_qrt(t_data *data, int qrt)
{
    int n, e;
    double d; /* I want to avoid that */

    d = qrt * data->count * 0.25 + 0.5;
    n = (int)d;
    e = n != d;
    data->qrt[qrt - 1] = data->value[n - 1];
    if (e) {
        data->qrt[qrt - 1] += data->value[n];
        data->qrt[qrt - 1] *= 0.5;
    }
}

static void set_qrts(t_data *data)
{
    set_qrt(data, 2);
    if (data->count > 1) {
        set_qrt(data, 1);
        set_qrt(data, 3);
    } else {
        data->qrt[0] = 0.0;
        data->qrt[2] = 0.0;
    }
}

static int comp(const void *pa, const void *pb)
{
    const double a = *(const double *)pa;
    const double b = *(const double *)pb;

    return (a > b) ? 1 : (a < b) ? -1 : 0;
}

int main(void)
{
    double values[] = {1.0, 2.0, 3.0};
    t_data data;

    data.value = values;
    data.count = (int)(sizeof(values) / sizeof(double));
    qsort(data.value, data.count, sizeof(double), comp);
    set_qrts(&data);
    printf("Q1 = %.1f\nQ2 = %.1f\nQ3 = %.1f\n", data.qrt[0], data.qrt[1], data.qrt[2]);
}
4

1 に答える 1

1

あなたが何を望んでいるのかわかりませんが、これらの2行を変更したい場合:

d = qrt * data->count * 0.25 + 0.5;
n = (int)d;

d を使用して整数値を直接取得するのではなく、次のことを行う必要があります。

n = (qrt * data->count +2)/4;

そして、これが単なる切り捨ての実数であるかどうかを確認するには:

e = ((qrt * data->count +2) % 4) != 0;

このようにして、n が 10 進数かどうかがわかり、その値が得られます

于 2013-07-30T18:33:59.057 に答える