我正在使用以下代码(并按预期工作)查找Q1、Q2和Q3,但我无法仅使用set_qrt()
和int
来编写%
以查找位置
对于1.0, 2.0, 3.0
四分位数必须是q1=1.5;q2=2.0;q3=2.5
对于1.0, 2.0, 3.0, 4.0, 5.0, 6.0
四分位数必须是q1=2.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]);
}
最佳答案
我不知道你想要什么,但如果你想改变这两行:
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是否是十进制数,并且得到它的值
关于c - 寻找四分位数而不加倍,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/17954497/