C++ 找出map<string,int>M中的最小值
时间: 2023-12-08 14:04:16 浏览: 181
可以使用迭代器遍历map中的所有键值对,然后比较每个值,找到最小值。示例代码如下:
```c++
#include <iostream>
#include <map>
#include <string>
using namespace std;
int main() {
map<string, int> M{{"apple", 3}, {"banana", 2}, {"orange", 5}, {"mango", 1}};
int min_val = INT_MAX; // 初始化最小值为正无穷大
for (auto const& [key, val] : M) {
if (val < min_val) {
min_val = val;
}
}
cout << "The minimum value in the map is " << min_val << endl;
return 0;
}
```
输出结果为:
```
The minimum value in the map is 1
```
相关问题
如何用编程语言找出一组包含十个整数中的最大值和最小值?
在大多数编程语言中,找到一组包含十个整数的最大值和最小值是比较常见的任务。以下是几种常见编程语言的示例:
**Python:**
```python
def find_min_max(numbers):
min_value = min(numbers)
max_value = max(numbers)
return min_value, max_value
numbers = [int(i) for i in range(10)] # 创建一个包含10个整数的列表
min_num, max_num = find_min_max(numbers)
print(f"最小值: {min_num}, 最大值: {max_num}")
```
**Java:**
```java
import java.util.Arrays;
public class Main {
public static void main(String[] args) {
int[] numbers = new int[10]; // 初始化一个包含10个整数的数组
Arrays.fill(numbers, 0); // 或者你可以自己填充这10个数字
int minValue = Arrays.stream(numbers).min().getAsInt();
int maxValue = Arrays.stream(numbers).max().getAsInt();
System.out.println("最小值: " + minValue + ", 最大值: " + maxValue);
}
}
```
**JavaScript (ES6):**
```javascript
function findMinMax(arr) {
let min = Math.min(...arr);
let max = Math.max(...arr);
return [min, max];
}
let numbers = [...Array(10)].map((_, i) => i); // 创建一个包含10个整数的数组
let result = findMinMax(numbers);
console.log(`最小值: ${result[0]}, 最大值: ${result[1]}`);
```
**C++ (STL):**
```cpp
#include <vector>
#include <algorithm>
int main() {
std::vector<int> numbers(10); // 创建一个包含10个整数的向量
// ...(填充数值)
int min_value = *std::min_element(numbers.begin(), numbers.end());
int max_value = *std::max_element(numbers.begin(), numbers.end());
std::cout << "最小值: " << min_value << ", 最大值: " << max_value << std::endl;
return 0;
}
```
在这些例子中,首先创建了一个包含10个整数的数据结构,然后使用内置函数或库方法来找到最小值和最大值。
阅读全文