小 X 的 AK 计划

博客围绕小 X 的 AK 计划展开,介绍用贪心算法解决该问题的思路。先将机房按坐标从小到大排序,逐个枚举,若时间足够则 AK,若不够但花费时间更短则放弃前面的选择该机房,最后输出能 AK 的数量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

小 X 的 AK 计划

在这里插入图片描述

思路

这道题其实可以用贪心来做。
先把机房按坐标从小到大排序,接着一个一个枚举,如果时间足够就AK,如果不够但是说花费的时间更短则前面的不AK,AK这个。
最后输出能AK的数量,就可以了。

代码

#include<cstdio>
#include<iostream>
#include<cmath>
#include<algorithm>
using namespace std;
struct note
{
	long long x,y;
}a[100001];
long long n,m,f[100001],x,y,mm,an[100001],ans,m1;
bool cmp(note x,note y)
{
	return x.x<y.x;
}
int main()
{
	scanf("%lld%lld",&n,&m);//读入
	for (long long i=1;i<=n;i++) scanf("%lld%lld",&a[i].x,&a[i].y);//读入
	sort(a+1,a+n+1,cmp);//按坐标从小到大排序
	for (long long i=1;i<=n;i++)
	if (m1+a[i].y<=m-a[i].x)//如果还有时间AK
	{
		m1+=an[++ans]=a[i].y;//就AK
	}
	else if (a[i].y<an[ans])//如果新的AK时间更短
	{
		m1-=an[ans]-a[i].y;//替换,前面的不AK,AK后面的
		an[ans]=a[i].y;
	}
	printf("%lld",ans);//输出
	return 0;
}
对于在qcom see上添加ak0997x传感器HAL层代码,可以参考以下步骤: 1. 在`/vendor/qcom/opensource/sensors`目录下创建`ak0997x`目录,用于存放传感器的驱动代码和HAL层代码。 2. 在`/vendor/qcom/opensource/sensors/ak0997x`目录下创建`Android.mk`文件,用于编译传感器驱动代码和HAL层代码。示例代码如下: ```makefile LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) LOCAL_MODULE := qcom_ak0997x LOCAL_MODULE_TAGS := optional LOCAL_C_INCLUDES := $(LOCAL_PATH)/include LOCAL_SRC_FILES := \ ak0997x.c \ qcom_ak0997x.c LOCAL_MODULE_STL := libc++ include $(BUILD_SHARED_LIBRARY) ``` 其中,`ak0997x.c`为传感器驱动代码,`qcom_ak0997x.c`为HAL层代码。需要根据具体的传感器和硬件平台进行调整。 3. 实现传感器驱动代码`/vendor/qcom/opensource/sensors/ak0997x/ak0997x.c`。该代码负责与硬件交互,读取传感器数据并提供给HAL层使用。示例代码如下: ```c #include <linux/i2c-dev.h> #include <sys/ioctl.h> #include <fcntl.h> #include <string.h> #include <unistd.h> #include <stdlib.h> #include <stdint.h> #include <errno.h> #define AK0997X_I2C_ADDR 0x0C #define AK0997X_REG_WIA1 0x00 #define AK0997X_REG_ST1 0x10 #define AK0997X_REG_HXL 0x11 #define AK0997X_REG_HXH 0x12 #define AK0997X_REG_HYL 0x13 #define AK0997X_REG_HYH 0x14 #define AK0997X_REG_HZL 0x15 #define AK0997X_REG_HZH 0x16 static int ak0997x_i2c_read(int fd, uint8_t reg, uint8_t *buf, uint32_t len) { int ret; uint8_t cmd[1] = {reg}; struct i2c_rdwr_ioctl_data msgset; struct i2c_msg msgs[2]; msgs[0].addr = AK0997X_I2C_ADDR; msgs[0].flags = 0; msgs[0].len = 1; msgs[0].buf = cmd; msgs[1].addr = AK0997X_I2C_ADDR; msgs[1].flags = I2C_M_RD; msgs[1].len = len; msgs[1].buf = buf; msgset.msgs = msgs; msgset.nmsgs = 2; ret = ioctl(fd, I2C_RDWR, &msgset); if (ret < 0) { return ret; } return len; } int ak0997x_read_data(int32_t *data) { int fd; uint8_t buf[6]; int ret; fd = open("/dev/i2c-4", O_RDWR); if (fd < 0) { return -errno; } ret = ak0997x_i2c_read(fd, AK0997X_REG_HXL, buf, sizeof(buf)); if (ret < 0) { close(fd); return ret; } data[0] = ((int16_t)buf[1] << 8) | buf[0]; data[1] = ((int16_t)buf[3] << 8) | buf[2]; data[2] = ((int16_t)buf[5] << 8) | buf[4]; close(fd); return 0; } ``` 其中,`ak0997x_i2c_read`函数用于通过I2C总线读取传感器数据,`ak0997x_read_data`函数用于读取传感器数据并返回给HAL层使用。 4. 实现传感器HAL层代码`/vendor/qcom/opensource/sensors/ak0997x/qcom_ak0997x.c`。该代码负责与Android系统交互,提供传感器服务。示例代码如下: ```c #include <hardware/sensors.h> #define QCOM_AK0997X_SENSOR_HANDLE 0 static const struct sensor_t sSensorList[] = { { .name = "qcom ak0997x", .vendor = "qcom", .version = 1, .handle = QCOM_AK0997X_SENSOR_HANDLE, .type = SENSOR_TYPE_MAGNETIC_FIELD, .maxRange = 2000.0f, .resolution = 0.6f, .power = 0.1f, .minDelay = 10000, .maxDelay = 20000, }, }; static int qcom_ak0997x_init(struct sensors_poll_device_t *dev) { // 初始化传感器并设置相关参数 return 0; } static int qcom_ak0997x_activate(struct sensors_poll_device_t *dev, int handle, int enabled) { // 激活或关闭传感器 return 0; } static int qcom_ak0997x_setDelay(struct sensors_poll_device_t *dev, int handle, int64_t ns) { // 设置传感器采样周期 return 0; } static int qcom_ak0997x_poll(struct sensors_poll_device_t *dev, sensors_event_t *data, int count) { // 读取传感器数据并返回给上层应用 int32_t mag_data[3] = {0}; ak0997x_read_data(mag_data); data->version = sizeof(sensors_event_t); data->sensor = QCOM_AK0997X_SENSOR_HANDLE; data->type = SENSOR_TYPE_MAGNETIC_FIELD; data->timestamp = getTimestamp(); data->magnetic.x = mag_data[0] * 0.6f; data->magnetic.y = mag_data[1] * 0.6f; data->magnetic.z = mag_data[2] * 0.6f; return 1; } static int qcom_ak0997x_close(struct hw_device_t *dev) { // 关闭传感器 return 0; } static int qcom_ak0997x_get_sensors_list(struct sensors_module_t* module, struct sensor_t const** list) { *list = sSensorList; return 1; } static struct hw_module_methods_t qcom_ak0997x_module_methods = { .open = NULL, }; struct sensors_module_t HAL_MODULE_INFO_SYM = { .common = { .tag = HARDWARE_MODULE_TAG, .module_api_version = SENSORS_MODULE_API_VERSION_0_1, .hal_api_version = HARDWARE_HAL_API_VERSION, .id = "qcom_ak0997x", .name = "qcom ak0997x module", .author = "qcom", .methods = &qcom_ak0997x_module_methods, }, .get_sensors_list = qcom_ak0997x_get_sensors_list, }; ``` 需要注意的是,上述代码中的函数实现需要根据具体的传感器类型和硬件平台进行调整。另外,还需要在Android源码中注册HAL层模块,才能在系统中使用该传感器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值