C语言:二维数组,(杨辉三角)
二维数组:一维数组中的元素又是一个数组。
声明的语法:
数据类型 数组名[一维长度][二维长度];
int num[3][2];
注意:int[][2];正确
int[2][];错误
二维数组中: 一维可以省略,二维不能省略。
1.创建一个二维数组用于保存三个班级的学生信息:
int scores[3][3];//用于保存三个班级的学生信息,每个班级3个人。
int i,j;
//为一班学生的成绩赋值
scores[0][0]=10;
scores[0][1]=20;
scores[0][2]=30;p
//为二班学生的成绩赋值
scores[1][0]=40;
scores[1][1]=50;
scores[1][2]=60;
//为三班学生的成绩赋值
scores[2][0]=70;
scores[2][1]=80;
scores[2][2]=90;
//二维数组的遍历
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
printf("%d\t",scores[i][j]);
}
printf("\n");
}
2.声明一个三行三列的二维数组,计算对角线的和:
int num[3][3];
int x,y,sum=0;
for(x=0;x<3;x++)
{
for(y=0;y<3;y++)
{
printf("请输入num[%d][%d]\n",x,y);
scanf("%d",&num[x][y]);
if(x==y)
{
sum+=num[x][y];
}
}
printf("\n");
}
printf("%d\n",sum);
3.从键盘上输入9个整数,保存在二维数组中按数组原来位置输出第一行和第一列的所有元素之和:
int nums[3][3];
int i,j,sum=0;
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
printf("请输入第%d行第%d列:",i+1,j+1);
scanf("%d",&nums[i][j]);
}
}
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
printf("%d\t",nums[i][j]);
//计算第一行和第一列所有元素之和
if(i==0||j==0)
{
sum+=nums[i][j];
}
}
printf("\n");
}
printf("第一行和第一列所有元素之和为%d:",sum);
4.求二维数组(3行3列)中最大元素值及其行列号:
int nums[3][3];
int i,j,z,y,sum=0,max;
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
printf("请输入第%d行第%d列:",i+1,j+1);
scanf("%d",&nums[i][j]);
}
}
max=nums[1][1];
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
printf("%d\t",nums[i][j]);
if(nums[i][j]>max)
{
max=nums[i][j];
z=i;
y=j;
}
}
printf("\n");
}
printf("最大的是%d,是第%d行%d列",max,z+1,y+1);
5.打印杨辉三角:
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
分析:
1.声明一个二维数组用于保存杨辉三角中的数据 int nums[5][5];
2.第一列nums[i][0]和对角线上的数字(nums[i][i])为1。
3.除第一列和对角线上的数字之外,其余数字nums[i][j]=nums[i-1][j]+nums[i-1][j-1];
int nums[5][5];
//为第一列和对角线赋值为1
int i,j;
for(i=0;i<5;i++)
{
nums[i][0]=1;//为第一列上的元素赋值为1
nums[i][i]=1;//为对角线上的元素赋值为1
}
//为除第一列和对角线之外元素赋值
for(i=2;i<5;i++)
{
for(j=1;j<i;j++)
{
nums[i][j]=nums[i-1][j]+nums[i-1][j-1];
}
}
//遍历输出
for(i=0;i<5;i++)
{
for(j=0;j<=i;j++)
{
printf("%d\t",nums[i][j]);
}
printf("\n");
}
C语言:二维数组,(杨辉三角)的更多相关文章
- java基础之二维数组-杨辉三角
首先呢你要知道什么是杨辉三角? 答:杨辉三角,是二项式系数在三角形中的一种几何排列. 简单的说一下就是两个未知数和的幂次方运算后的系数问题,比如(x+y)的平方=x的平方+2xy+y的平方,这样系数就 ...
- c语言二维数组传递
c语言二维数组传递,目前我总结三种方法,以及纠正一个不能使用的方法 /********************************* * 方法1: 第一维的长度可以不指定 * * 但必须指定第二维 ...
- C语言二维数组作业
一.PTA实验作业 题目1:7-3 出生年 1. 本题PTA提交列表 2. 设计思路 1.声明一个函数different()用来计算一个年份的不同数字个数 2.定义y(y是来计算符合要求的年份的量), ...
- 基于visual Studio2013解决C语言竞赛题之0509杨辉三角
题目
- 关于c语言二维数组与指针的个人理解及处理办法。
相信大家在学习C语言时,对一维数组和指针的理解应该是自信的,但是,我在学习过程中,看到网上一些博文,发现即便是参加工作的一些专业编程人员,突然碰到二维数组和指针的问题时,也可能会遇到难以处理的诡异问题 ...
- C语言 二维数组复制、清零及打印显示
#include <stdlib.h> #include <stdio.h> #include <string.h> //二维整型数组打印显示 ],int row, ...
- C语言 二维数组(指针)动态分配和释放(转)
C 二维数组(指针)动态分配和释放 先明确下概念: 所谓32位处理器就是一次只能处理32位,也就是4个字节的数据,而64位处理器一次就能处理64位,即8个字节的数据.如果我们将总长128位的指令分别按 ...
- C语言二维数组
上节讲解的数组可以看作是一行连续的数据,只有一个下标,称为一维数组.在实际问题中有很多数据是二维的或多维的,因此C语言允许构造多维数组.多维数组元素有多个下标,以确定它在数组中的位置.本节只介绍二维数 ...
- C语言二维数组作为函数参数
设有整型二维数组a[3][4]如下:0 1 2 34 5 6 78 9 10 11 它的定义为: int a[3][4]={{0,1,2,3},{4,5,6,7} ...
- C语言二维数组作为函数的参数
前言:今天在实现装配线调度程序时候,用到了二维数组,并将其作为函数的参数.在写程序的时候,遇到一些问题,即二维数组做函数的参数应该如何正确表示.我写程序的错误如下程序所示: #include < ...
随机推荐
- Codeforce Round #424
A 略 B 略 C: 先对Ai数列预处理前缀和 然后把Bi的每个都加一次 最终得到的结果为ans[sum]++; 最后如果有一个ans[sum]>=k即满足所有K个条件就输出(注意!!前缀和要进 ...
- Liux chmod 给文件夹赋权限
777 最高权限 给文件夹及子文件夹赋权限 chmod -R 777 * 给单独文件赋权限 chmod -R 777 ./startup.sh
- 集合(七) Set—HashSet,TreeSet和LinkedHashSet
四.Set Set和List一样,也是继承Collection的接口,但Set是不包含重复元素的集合.由于先啃下Map,Set的难度将会大幅减小.因为Set基本上都是以Map为基础实现的,例如两个主要 ...
- TXNLP 01-09
一般涉及生成文本都是比较难的.
- Python3-Set
# Set(集合) # 集合(set)是一个无序不重复元素的序列. # 基本功能是进行成员关系测试和删除重复元素. # 可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须 ...
- Kafka、RabbitMQ、RocketMQ等消息中间件的介绍和对比(转)
前言在分布式系统中,我们广泛运用消息中间件进行系统间的数据交换,便于异步解耦.现在开源的消息中间件有很多,前段时间产品 RocketMQ (MetaQ的内核) 也顺利开源,得到大家的关注. 概念MQ简 ...
- php文件夹上传源码
1.使用PHP的创始人 Rasmus Lerdorf 写的APC扩展模块来实现(http://pecl.php.net/package/apc) APC实现方法: 安装APC,参照官方文档安装,可以使 ...
- P4981 父子 Cayley公式
CayleyCayley公式的定义是这样的,对于n个不同的节点,能够组成的无根树(原来是无向连通图或者是有标志节点的树)的种数是n^(n-2)种.(这里让大家好理解一点,就写成了无根树,其实应该是一样 ...
- hdu 5533 正n边形判断 精度处理
Dancing Stars on Me Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Ot ...
- CDQ解决一些三维偏序的问题
本来几天前就该记录的东西,硬生生被我拖到了现在,太懒了... 在cdq学习时,二维偏序已经解决了,无非就是先sort使第一维有序,然后再用cdq或者数据结构处理第二维.而三维偏序的时候呢,大佬的做法好 ...