C# 按行列输入二维数组的每个元素的值
2017-11-04 20:41
134 查看
相信很多初学C#的人都跟我一样有类似的疑惑,那就是C#怎么不能按照元素在二维数组中的位置依次输入他的值呢?就像这样
不管是在C,Java等语言中都可以这么输入的,那么C#不可以吗?答案是否定的,C#也是可以的,我在这整理了两种方法与大家分享:
*此处均以int型为例。
方法一:利用 Console.ReadLine() 和 Split() 方法
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace TEMP
{
class Program
{
static void Main(string[] args)
{
int[,] a = new int[3, 4];
Console.WriteLine("请输入二维数组的值:");
//按样例输入二维数组
for (int i = 0; i < 3; i++)
{
string str = Console.ReadLine();//首先输入一字符串,表示二维数组的一行数据
string[] tmp = str.Split(" ".ToCharArray());//通过Split方法以空格作为分隔符将输入的一行字符串分隔开
for (int j = 0; j < 4; j++)
{
a[i, j] = int.Parse(tmp[j]);//将分割后的字符付给二维数组每个元素
}
}
Console.WriteLine("二维数组为:");
//输出二维数组
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 4; j++)
Console.Write(a[i, j] + " ");
Console.WriteLine();
}
}
}
}
代码执行结果如下图所示:
方法二:利用 Console.Read() 方法依次接受每个元素的值,分隔符单独接收但不做处理。
*注意:该方法只能接收元素值为单个字符的情况,其他情况各位可以稍加修改。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace TEMP
{
class Program
{
static void Main(string[] args)
{
int[,] num = new int[2, 3];
Console.WriteLine("输入:");
for (int i = 0; i < 2; i++)
{
for (int j = 0; j < 3; j++)
{
num[i, j] = Console.Read() - 48;//接收一个字符
int temp = Console.Read();//接收分隔符
if (j == 2)
Console.Read();//每输完一行吸收掉换行符
}
}
Console.WriteLine("输出:");
for (int i = 0; i < 2; i++)
{
for (int j = 0; j < 3; j++)
Console.Write(num[i, j]+" ");
Console.WriteLine();
}
}
}
}
代码执行结果:
代码执行结果如下图所示:
不管是在C,Java等语言中都可以这么输入的,那么C#不可以吗?答案是否定的,C#也是可以的,我在这整理了两种方法与大家分享:
*此处均以int型为例。
方法一:利用 Console.ReadLine() 和 Split() 方法
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace TEMP
{
class Program
{
static void Main(string[] args)
{
int[,] a = new int[3, 4];
Console.WriteLine("请输入二维数组的值:");
//按样例输入二维数组
for (int i = 0; i < 3; i++)
{
string str = Console.ReadLine();//首先输入一字符串,表示二维数组的一行数据
string[] tmp = str.Split(" ".ToCharArray());//通过Split方法以空格作为分隔符将输入的一行字符串分隔开
for (int j = 0; j < 4; j++)
{
a[i, j] = int.Parse(tmp[j]);//将分割后的字符付给二维数组每个元素
}
}
Console.WriteLine("二维数组为:");
//输出二维数组
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 4; j++)
Console.Write(a[i, j] + " ");
Console.WriteLine();
}
}
}
}
代码执行结果如下图所示:
方法二:利用 Console.Read() 方法依次接受每个元素的值,分隔符单独接收但不做处理。
*注意:该方法只能接收元素值为单个字符的情况,其他情况各位可以稍加修改。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace TEMP
{
class Program
{
static void Main(string[] args)
{
int[,] num = new int[2, 3];
Console.WriteLine("输入:");
for (int i = 0; i < 2; i++)
{
for (int j = 0; j < 3; j++)
{
num[i, j] = Console.Read() - 48;//接收一个字符
int temp = Console.Read();//接收分隔符
if (j == 2)
Console.Read();//每输完一行吸收掉换行符
}
}
Console.WriteLine("输出:");
for (int i = 0; i < 2; i++)
{
for (int j = 0; j < 3; j++)
Console.Write(num[i, j]+" ");
Console.WriteLine();
}
}
}
}
代码执行结果:
代码执行结果如下图所示:
相关文章推荐
- USTC机试—从键盘输入 N,建立 N*N矩阵,每个元素是一个字符串,为每个元素赋值。然后求 出按字典序排列最大的元素所在的行列。
- 互换二维数组的行列。要求数组的行数、列数以及各元素均从键盘输入;输出互换前数组内容和互换后数组内容。(要求循环输入进行测试)Java
- 【程序29】 TestAdd3.java 题目:求一个3*3矩阵对角线元素之和 1.程序分析:利用双重for循环控制输入二维数组, //再将a[i][i]累加后输出。
- 对数组的每个元素仍是数组的遍历方法,c#,foreach,for
- 从C#输入到excel要如何控制每个单元格的边框线是否可见
- 定义一个一维数组,其元素个数从键盘中输入,元素的值为[100,200]的随机整数。 (1)输出数组的每个数 (2)对数组的数进行升序排序,输出排序后的数组元素 (3)从键盘上输入一个整数,查找该整数是
- 用vector<int>对象元素,实现输入10数,将每个奇数值元素用该值的两倍替换
- 设一个长度为10的整型数组, 0)要求每个元素的值通过scanf输入,输入完成后, 1)请顺序输出这些整数, 2)请倒序输出这些整数, 3)输出这些数中的最大值, 4)输出这些数中的最小值
- 网易游戏笔试题:输入一个数n,返回一个数组,数组中每个元素对应[0,n]每个数的二进制中1的个数
- 从C#输入到excel要如何控制每个单元格的边框线是否可见
- 《CTCI》1.7 二维数组的含0元素所在行列清零
- 输入10个整数,将它们从小到大排序后输出,并给出现在每个元素在原来序列中的位置。
- 8.9 编写函数打开文件用于输入,将文件内容读入 string 类型的 vector 容器,每一行存储为该容器对象 的一个元素。8.10 重写上面的程序,把文件中的每个单词存储为 容器的一个元素
- 编写一个C#程序,要求从键盘输入10个数存放在数组中,分别求出最大数和最小数存放在第一第二个元素里
- 编写一个C#程序,要求定义一个行数和列数相等的二维数组, 并执行初始化,然后计算并输出数组两条对角线上的元素之和。
- 输入10个整数,将它们从小到大排序后输出,并给出现在每个元素在原来序列中的位置。
- Java平台 针对行列相等的二维数组非对角元素求法
- 【1】 设一个长度为10的整型数组,  0)要求每个元素的值通过scanf输入,输入完成后,  1)请顺序输出这些整数,  2)请倒序输出这些整数,  3)输出这些数中的最大值,最小值
- c# 二维数组 行列
- 给定一个整数数组,两个数字的返回索引将它们加到一个特定的目标中。 您可以假设每个输入都只有一个解决方案,并且您可能不会两次使用相同的元素。