酷代码 AI
菜单
服务商
DeepSeek字节豆包讯飞星火
更多选项

C++实现:判断斗地主纸牌能否连成顺子,含代码及注意要点!

以下是用 C++ 实现的代码: ```cpp #include <iostream> #include <vector> #include <algorithm> bool isStraight(std::vector<int>& nums) { // 对输入的数字进行排序 std::sort(nums.begin(), nums.end()); int zeroCount = 0; // 统计 0 的个数 for (int num : nums) { if (num == 0) { zeroCount++; } } // 检查相邻数字的差值 for (int i = zeroCount; i < nums.size() - 1; i++) { if (nums[i + 1] == nums[i]) { return false; } if (nums[i + 1] - nums[i] > 1) { // 差值大于 1 时,用 0 来填补 if (nums[i + 1] - nums[i] - 1 > zeroCount) { return false; } zeroCount -= nums[i + 1] - nums[i] - 1; } } return true; } int main() { int n; std::cin >> n; std::vector<int> nums(n); for (int i = 0; i < n; i++) { std::cin >> nums[i]; } if (n == 1) { std::cout << nums[0] << std::endl; } else { if (isStraight(nums)) { std::cout << "yes" << std::endl; } else { std::cout << "no" << std::endl; } } return 0; } ``` 1. 输入数据时,要确保输入的是有效的整数。 2. 处理边界情况,如输入的数字数量为 0 或负数。 3. 考虑代码的效率和可读性,对于大规模数据输入的处理能力。 ######[AI写代码神器 | 466点数解答 | 2024-12-22 19:10:37]

相关提问
本站限时免费提问中
实用工具查看更多
Linux在线手册 [开发类]
Jquery在线手册 [开发类]
今日油价 [生活类]
图片互转base64 [开发类]
时间转换器 [开发类]