请根据每日 气温 列表 temperatures ,重新生成一个列表,要求其对应位置的输出为:要想观测到更高的气温,至少需要等待的天数。如果气温在这之后都不会升高,请在该位置用 0 来代替。 示例 1: 输入: temperatures = [73,74,75,71,69,72,76,73] 输出: [1,1,4,2,1,1,0,0] 示例 2: 输入: temperatures = [30,40,50,60] 输出: [1,1,1,0] 示例 3: 输入: temperatures = [30,60,90] 输出: [1,1,0] 提示: 1 <= temperatures.length <= 105 30 <= temperatures[i] <= 100
时间: 2023-03-10 07:43:00 浏览: 85
示例 1: 输入:temperatures = [73, 74, 75, 71, 69, 72, 76, 73] 输出:[1, 1, 4, 2, 1, 1, 0, 0] 示例 2: 输入:temperatures = [30, 40, 50, 60] 输出:[1, 1, 1, 0] 示例 3: 输入:temperatures = [30, 60, 90] 输出:[1, 1, 0]根据您的描述,您希望使用温度列表temperatures来生成一个新的列表,该列表中的值表示要想观测到更高的气温,至少需要等待的天数。如果气温在此之后不会升高,则将0作为该位置的输出值。根据此,我们可以生成示例 1、2和3中提到的输出列表。
相关问题
用C语言根据每日 气温 列表 temperatures ,重新生成一个列表,要求其对应位置的输出为:要想观测到更高的气温,至少需要等待的天数。如果气温在这之后都不会升高,请在该位置用 0 来代替。
答:可以使用以下代码片段来实现:int[] result = new int[temperatures.length];
for (int i=0; i<temperatures.length; i++) {
int temp = temperatures[i];
int count = 0;
for (int j=i+1; j<temperatures.length; j++) {
if (temperatures[j] > temp) {
count = j - i;
break;
}
}
if (count == 0)
result[i] = 0;
else
result[i] = count;
}
用C语言函数实现根据每日 气温 列表 temperatures ,重新生成一个列表,要求其对应位置的输出为:要想观测到更高的气温,至少需要等待的天数。如果气温在这之后都不会升高,请在该位置用 0 来代替。
答:可以使用以下C语言函数来实现:int* days_waiting_for_higher_temperatures(int temperatures[], int n) {
int* result = (int*)malloc(n * sizeof(int));
int max = temperatures[0];
int count = 0; for (int i = 0; i < n; i++) {
if (temperatures[i] > max) {
max = temperatures[i];
count = 0;
}
else {
count++;
}
result[i] = count;
}
return result;
}