#include <stdio.h> void Swap(int *a, int *b) { // 交换函数 int temp = *a; *a = *b; *b = temp; } int main() { int n, s = 0; scanf("%d", &n); int time[n]; printf("输入等待时间:"); for (int i = 0; i < n; i++) { scanf("%d", &time[i]); } // 所需服务时间排序 for (int i = 0; i < n; i++) { for (int j = i + 1; j < n; j++) { if (time[i] > time[j]) { Swap(&time[i], &time[j]); } } } // 打印升序排序数组 // for (int i = 0; i < n; i++) // { // printf("%d ", time[i]); // } //计算等待总时长 for (int i = 0; i < n; i++) { s += time[i] * (n - i); } float avg = s * 1.0 / n; printf("\n平均等待时长为:%.2f\n", avg); return 0; }
时间: 2024-04-28 16:26:44 浏览: 83
#include <stdio.h>
_Channel, DMA_IT_TC, ENABLE);
}
void WM8690_Init(void)
{
uint8_t buffer[2];
/* Configure WM这段代码实现了一个简单的排队等待时间计算器,用户可以输入 n 个人的等待8690 */
buffer[0] = 0x00;
buffer[1] = 0x01; // Power on时间,程序会自动计算出这些人的平均等待时间。具体实现流程如下:
1
I2C_GenerateSTART(I2C1, ENABLE);
while(!I2C_CheckEvent(I2C1, I. 用户输入 n,表示有 n 个人排队等待服务。
2. 用户依次输入每个人的等待2C_EVENT_MASTER_MODE_SELECT));
I2C_Send7bitAddress(I2C1, WM8690_ADDR, I2C_D时间,程序将这些等待时间存储在数组 time 中。
3. 程序对数组 time 进行升序排序,irection_Transmitter);
while(!I2C_CheckEvent(I2C1, I2C_EVENT_MASTER_TRANSMITTER_MODE_SELECTED));
这里使用了冒泡排序算法。
4. 程序计算每个人的等待时间,等待时间 = 排 I2C_SendData(I2C1, buffer[0]);
while(!I2C_CheckEvent(I2C1, I2在这个人后面的人数 * 这个人的等待时间。
5. 程序计算所有人的等待C_EVENT_MASTER_BYTE_TRANSMITTED));
I2C_SendData(I2C1, buffer[1]);
while(!I2时间之和,并除以 n 得到平均等待时间。
6. 程序输出平均等待时间。
需要注意的是,这段代码中使用了交换函数 Swap 来交换数组中的两个元素,这是为了方便C_CheckEvent(I2C1, I2C_EVENT_MASTER_BYTE_TRANSMITTED));
I2C_GenerateSTOP(I2C代码编写和阅读。另外,程序中的注释部分是为了方便调试和理解,如果1, ENABLE);
}
void NVIC_Configuration(void)
{
NVIC_InitTypeDef NVIC_InitStructure;
/* Enable DMA1 channel5 IRQ Channel需要打印出排序后的数组,可以取消注释部分代码。
阅读全文