鱼C论坛

 找回密码
 立即注册
查看: 126|回复: 6

输入

[复制链接]
发表于 2024-4-21 12:23:50 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
c++怎么接收不知道个数的输入
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-4-21 12:24:00 | 显示全部楼层
在C++中,要接受不知道个数的输入,可以使用循环结构来实现。下面是一个示例代码:

  1. #include <iostream>
  2. #include <vector>

  3. int main() {
  4.     std::vector<int> inputNumbers;  // 用于存储输入的数字

  5.     std::cout << "请输入数字,输入0结束:";

  6.     int num;
  7.     while(std::cin >> num && num != 0) {  // 输入数字,直到输入0为止
  8.         inputNumbers.push_back(num);  // 将输入的数字添加到容器中
  9.     }

  10.     // 输出输入的数字
  11.     std::cout << "你输入的数字为:";
  12.     for (int i = 0; i < inputNumbers.size(); i++) {
  13.         std::cout << inputNumbers[i] << " ";
  14.     }
  15.     std::cout << std::endl;

  16.     return 0;
  17. }
复制代码


上述代码中,我们使用了一个`std::vector<int>`来存储输入的数字。通过使用循环结构,我们可以连续接收输入的数字并将其添加到向量中,直到输入的数字为0时停止。然后,我们可以使用另一个循环来遍历并输出向量中的数字。

请注意,输入0时程序会终止循环并输出结果。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-4-21 12:25:28 | 显示全部楼层
如果没有0做结尾,而是一个0和1组成的方阵但不知道边长呢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-21 12:25:38 | 显示全部楼层
Gordon1 发表于 2024-04-21 12:25
如果没有0做结尾,而是一个0和1组成的方阵但不知道边 ...


如果输入是一个由0和1组成的方阵,但我们不知道其边长,可以使用动态数组(二维向量)来接收输入。具体步骤如下所示:

  1. #include <iostream>
  2. #include <vector>
  3. using namespace std;

  4. int main() {
  5.     vector<vector<int>> matrix;  // 用于存储输入的方阵

  6.     string line;
  7.     while (getline(cin, line)) {  // 持续读取输入的每一行
  8.         vector<int> row;  // 存储当前行的数字
  9.         for (char c : line) {  // 遍历当前行的每个字符
  10.             int num = c - '0';  // 将字符转换为数字
  11.             row.push_back(num);  // 将数字添加到当前行
  12.         }
  13.         matrix.push_back(row);  // 将当前行添加到方阵中
  14.     }

  15.     // 输出输入的方阵
  16.     for (const auto& row : matrix) {
  17.         for (int num : row) {
  18.             cout << num << " ";
  19.         }
  20.         cout << endl;
  21.     }

  22.     return 0;
  23. }
复制代码


这段代码通过循环读取每一行输入,并将每行的数字存储在一个二维向量中。最后输出存储的方阵。请注意,在这个示例中,假设输入的每一行只包含0和1,并且每个字符之间没有空格。根据实际情况,你可能需要根据输入格式进行适当的调整。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-4-21 12:32:46 | 显示全部楼层
有用数组的方法吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-21 12:32:56 | 显示全部楼层
Gordon1 发表于 2024-04-21 12:32
有用数组的方法吗


当我们不知道方阵的边长时,可以使用二维数组来接收输入。下面是一个使用动态分配二维数组的示例代码:

  1. #include
  2. #include

  3. int main() {
  4.     int** matrix;  // 用于存储输入的方阵

  5.     // 获取方阵的行数和列数
  6.     int rows = 0;
  7.     int cols = 0;
  8.     std::string line;
  9.     while (getline(std::cin, line)) {
  10.         if (line.empty()) {  // 输入为空行时结束循环
  11.             break;
  12.         }
  13.         rows++;
  14.         cols = line.length();
  15.     }
  16.    
  17.     // 动态分配二维数组
  18.     matrix = new int*[rows];
  19.     for (int i = 0; i < rows; i++) {
  20.         matrix[i] = new int[cols];
  21.     }

  22.     // 读取输入的方阵
  23.     std::istringstream iss(line);
  24.     int row = 0;
  25.     do {
  26.         for (int col = 0; col < cols; col++) {
  27.             char c;
  28.             if (iss >> c) {
  29.                 matrix[row][col] = c - '0';
  30.             }
  31.         }
  32.         row++;
  33.     } while (getline(std::cin, line));

  34.     // 输出输入的方阵
  35.     for (int i = 0; i < rows; i++) {
  36.         for (int j = 0; j < cols; j++) {
  37.             std::cout << matrix[i][j] << " ";
  38.         }
  39.         std::cout << std::endl;
  40.     }

  41.     // 释放动态分配的内存
  42.     for (int i = 0; i < rows; i++) {
  43.         delete[] matrix[i];
  44.     }
  45.     delete[] matrix;

  46.     return 0;
  47. }
复制代码


请注意,在使用完二维数组后,我们需要手动释放动态分配的内存,以避免内存泄漏。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-21 19:13:17 | 显示全部楼层
本帖最后由 jackz007 于 2024-4-21 19:17 编辑

        没什么好办法,得自行处理键盘输入,请参考下面的代码
  1. #include <stdio.h>

  2. int input(int d[])
  3. {
  4.         char s[2048]                                                          ;
  5.         int b , k , m , n                                                     ;
  6.         fgets(s , 2048 , stdin)                                               ;
  7.         for(n = 0 ; s[n] ; n ++)                                              ;
  8.         for(b = k = m = 0 ; b < n - 1 && k < n - 1 ;) {
  9.                 for(b = k ; b < n - 1 && (s[b] == ' ' || s[b] == ',') ; b ++) ;
  10.                 for(k = b ; k < n - 1 && s[k] != ' ' && s[k] != ',' ; k ++)   ;
  11.                 if(b < n - 1) sscanf(& s[b] , "%d" , & d[m ++])               ;
  12.         }
  13.         return m                                                              ;
  14. }

  15. int main(void)
  16. {
  17.         int d[256] , i , n                                                    ;
  18.         printf("请输入多个整数:")                                            ;
  19.         n = input(d)                                                          ;
  20.         if(n) {
  21.                 printf("%d" , d[0])                                           ;
  22.                 for(i = 1 ; i < n ; i ++) printf(", %d" ,  d[i])              ;
  23.                 printf("\n")                                                  ;
  24.         }                                   
  25. }
复制代码

        编译、运行实况:
  1. D:\[exercise]\C>g++ -o x x.c

  2. D:\[exercise]\C>x
  3. 请输入多个整数:7 3 2 8 6 9 1 4 5
  4. 7, 3, 2, 8, 6, 9, 1, 4, 5

  5. D:\[exercise]\C>
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-18 13:02

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表