程序设计入门-C语言基础知识-翁恺-第六周:数组-详细笔记(六)

目录

  • 第六章:数组
    • 6-1 数组
    • 6-2 数组计算
    • 6.3 课后习题

第六章:数组

6-1 数组

题目:让用户输入一组整数以-1结束输入,算出这组数的平均值,并且输出大于平均值的数。

  • 我们需要记录用户所有输入的数字才能在判断出平均值后输出大于平均值的数,这里要用到一个新的数据类型数组。

程序实现:

#ifndef biggerThanAvg_h 
#define biggerThanAvg_h#include <stdio.h>
void biggerThanAvg(void);
#endif#include "biggerThanAvg.h"void biggerThanAvg(void)
{int x;double sum = 0;double avg = 0;int cnt = 0;int number[100];printf("请输入一些整数以-1结束:");scanf("%d", &x);while (x != -1){number[cnt] = x;sum += x;cnt++;scanf("%d", &x);}if (cnt > 0){avg = sum / cnt;printf("%f\n", avg);for (int i = 0; i < cnt; i++){if (number[i] > avg){printf("%d\n", number[i]);}}}
}#include <stdio.h>
#include "biggerThanAvg.h"int main(int argc, char *argv[])
{biggerThanAvg();return 0; 
}

测试样例:

请输入一些整数以-1结束:1 2 3 4 5 6 7 8 9 -1
5.000000
6
7
8
9--------------------------------
Process exited after 9.368 seconds with return value 0

定义数组

  • 变量名称[元素数量];
  • int grades[100];
  • double weight[20];
  • 元素数量必须是整数
  • C99之前:元素数量必须是编译时刻确定的字面量、常量

数组

  • 是一种容器(放东西的东西),特点是:
    • 其中所有的元素具有相同的数据类型
    • 一旦创建,不能改变大小
    • (数组中的元素在内存中是连续依次排列的)

数组的单元

  • 数组的每个单元就是数组类型的一个变量
  • 使用数组时放在[]中的数字叫做下标或索引,下标从0开始计数:
    • grades[0]
    • grades[99]
    • average[5]

有效的下标范围

  • 编译器和运行环境都不会检查数组下标是否越界,无论是对数组单元做读还是写
  • 一旦程序运行,越界数组可能造成问题,导致程序崩溃
    • segmentation fault
  • 但是也可能运气好,没造成严重的后果
  • 所以这是程序员的责任来保证程序只使用有效的下标值:[0,数组的大小 - 1]

使用数组程序的对应操作

  1. 数组大小
  2. 定义数组
  3. 初始化数组
  4. 数组参与运算
  5. 遍历数组输出

6-2 数组计算

数组初始化

  • 数组的集成初始化
    • int a[] = {2,4,5,7,3,4,5,6,7};
  • 集成初始化时的定位C99 ONLY
    • int a[10] = {
      [0] = 2, [2] = 3, 6,
      ]
  • 用[n]在初始化数据中给出定位
  • 没有定位的数据接在前面的位置后面,比如6就接在3的位置
  • 其他位置的值补零
  • 也可以不给出数组大小让编译器算
  • 特别适合初始数据稀疏的数组

数组的大小

  • sizeof给出整个数组所占据的内容的大小,单位是字节
    • sizeof(a)/sizeof(a[0])
  • sizeof(a[0])给出数组中单个元素的大小,于是相除就得到了数组的单元个数
  • 这样的代码,一旦修改数组中初始的数据,不需要修改遍历的代码

数组的赋值

  • 数组遍历本身不能被赋值
  • 要把一个数组的所有元素交给另一个数组,必须采用遍历
    • for (i=0; i<length; i++){ b[i] = a[i]; }

遍历数组

  • 通常都是使用for循环,让循环变量i从0到小于数组的长度,这样循环体内最大的i正好是数组最大的有效下标
  • 常见的错误是:
    • 循环结束条件是小于等于数组长度,或;
    • 离开循环后,继续用i的值来做数组元素的下标

*数组传参

  • 数组作为函数参数时,往往必须再用另一个参数来传入数组的大小
  • 数组在作为函数参数时:
    • 不能在[]中给出数组的大小
    • 不能再利用sizeof来计算数组元素个数

二维数组的初始化
int a[][5] ={
{0,1,2,3,4},
{2,3,4,5,6}
}

  • 列数是必须给出的,行数可以由编译器来数
  • 每行一个{},逗号分隔
  • 最后的逗号可以存在,有古老的传统
  • 如果省略,表示补零
  • 也可以用定位(* C99 ONLY)

6.3 课后习题

1、题目内容: 题目内容:
一个多项式可以表达为 x 的各次幂与系数乘积的和,比如:
2χ 6 +3χ 5 +12χ 3 +6χ+20
现在,你的程序要读入两个多项式,然后输出这两个多项式的和,也就是把对应的幂上的系
数相加然后输出。
程序要处理的幂最大为 100。
输入格式:
总共要输入两个多项式,每个多项式的输入格式如下:
每行输入两个数字,第一个表示幂次,第二个表示该幂次的系数,所有的系数都是整数。第
一行一定是最高幂,最后一行一定是 0 次幂。
注意第一行和最后一行之间不一定按照幂次降低顺序排列;如果某个幂次的系数为 0,就不
出现在输入数据中了;0 次幂的系数为 0 时还是会出现在输入数据中。
输出格式:
从最高幂开始依次降到 0 幂,如:
2x6+3x5+12x3-6x+20
注意其中的 x 是小写字母 x,而且所有的符号之间都没有空格,如果某个幂的系数为 0 则
不需要有那项。
输入样例:
6 2
5 3
3 12
1 6
0 20
6 2
5 3
2 12
1 6
0 20
输出样例:
4x6+6x5+12x3+12x2+12x+40

题目分析:

  • 求和其实就是将相同幂的常数项相加。
  • 要处理的最大的幂为100个
  • 可以用一个长度为100数组arr来存储两个多项式D1和D2的结果。
  • 用户第一次输入 0 n 代表第一个多项式结束,第二次输入 0 n代表第二个多项式结束
  • 我们用arr[0]表示多项式的系数为0的这个项的系数,1表示系数为1这个项的系数依此类推
  • 用户每输入一个多项式,根据幂次m将系数累加到对应的arr[m]中,直到用户输入完所有的多项式。
  • 最后从最高的系数开始输出整个多项式,如果某个幂次系数为0则不做输出,系数为0的幂次代表这个幂次下没有多项式。因此我们在做累加时需要记录最高的系数,以便输出。

程序实现:

#include <stdio.h>
#include "sumOfPolynomial.h";int main(int argc, char *argv[])
{sumOfPolynomial();return 0;
}#ifndef sumOfPolynomial_h
#define sumOfPolynomial_h#include <stdio.h>
void sumOfPolynomial(void);
#endif#include "sumOfPolynomial.h"void sumOfPolynomial(void)
{int arr[100] = {0};int polynomialIndex = 0; //为2时终止循环int power = 0; //幂次int coefficient = 0; //系数int maxPower = 0; //最高幂int i;printf("请输入两个多项式,幂次和系数以空格分开,幂次从高到低最后一项是0次幂:\n");//输入累加求和do{scanf("%d %d", &power, &coefficient);if (power == 0){polynomialIndex++;}if (power > maxPower){maxPower = power;}arr[power] += coefficient;} while (polynomialIndex < 2);//输出结果for (i = maxPower; i > -1; i--){if (arr[i] > 0){if (i == 0){printf("%d", arr[i]);}else{if (i == 1){printf("%dx", arr[i]);}else{printf("%dx%d", arr[i], i);}}}//不是最后一项且下一项的系数大于0才拼接加号if (i > 0 && arr[i - 1] > 0){printf("+");}}printf("\n");
}

测试样例:

请输入两个多项式,幂次和系数以空格分开,幂次从高到低最后一项是0次幂:
6 2
5 3
3 12
1 6
0 20
6 2
5 3
3 12
1 6
2 3
0 20
4x6+6x5+24x3+3x2+12x+40--------------------------------
Process exited after 40.41 seconds with return value 0请输入两个多项式,幂次和系数以空格分开,幂次从高到低最后一项是0次幂:
2 6
0 0
3 6
0 0
6x3+6x2--------------------------------
Process exited after 21.46 seconds with return value 0

2、题目内容:
给定一个 n*n 矩阵 A。矩阵 A 的鞍点是一个位置(i,j),在该位置上的元素是第 i 行上的
最大数,第 j 列上的最小数。一个矩阵 A 也可能没有鞍点。
你的任务是找出 A 的鞍点。
输入格式:
输入的第 1 行是一个正整数 n, (1<=n<=100),然后有 n 行,每一行有 n 个整数,同
一行上两个整数之间有一个或多个空格。
输出格式:
对输入的矩阵,如果找到鞍点,就输出其下标。下标为两个数字,第一个数字是行号,第二
个数字是列号,均从 0 开始计数。
如果找不到,就输出
NO
题目所给的数据保证了不会出现多个鞍点。
输入样例:
4
1 7 4 1
4 8 3 6
1 6 1 2
0 7 8 9
输出样例:
2 1

题目分析:

  • 既然是一个n*n的矩阵,我们可以用一个二维数组arr[n][n]来存储这个矩阵。
  • 鞍点是i行上最大的数,j列上最小的数。
  • 获取一行中最大的数num,再判断num是否该列最小的数如果是则为此矩阵的一个鞍点,否则继续判断下一行。

程序实现:

#include <stdio.h>
#include "getSaddlePointOfMatrix.h"int main(int argc, char *argv[])
{getSaddlePointOfMatrix();return 0;
}#ifndef getSaddlePointOfMatrix_h
#define getSaddlePointOfMatrix_h#include <stdio.h>
#include <limits.h>
void getSaddlePointOfMatrix(void);
int getMaxNumberColIndexByRow(int arr[4][4], int rowIndex, int colCount);
int getMinNumberByCol(int arr[4][4], int colIndex, int rowCount);
#endif
#include "getSaddlePointOfMatrix.h"
//获取一行中最大值的列坐标
int getMaxNumberColIndexByRow(int arr[4][4], int rowIndex, int colCount)
{int maxNumber = INT_MIN;//int最小值int maxColIndex = 0;int i;for (i = 0; i < colCount; i++){if (arr[rowIndex][i] > maxNumber){maxNumber = arr[rowIndex][i];maxColIndex = i;}}return maxColIndex;
}
//获取一列中最小的值
int getMinNumberByCol(int arr[4][4], int colIndex, int rowCount)
{int minNumber = INT_MAX;//int最大值int i;for (i = 0; i < rowCount; i++){if (arr[i][colIndex] < minNumber){minNumber = arr[i][colIndex];}}return minNumber;
}void getSaddlePointOfMatrix(void)
{int i, j;int rowIndex, colIndex;int maxRowNumber = 0;int minColNumber = 0;int n = 4;int isHaveSaddlePoint = 0;int arr[4][4] = {{1, 7, 4, 1},{4, 8, 3, 6},{1, 6, 1, 2},{0, 7, 8, 9}};//判断每一行的最大值是否为该列的最小值for (i = 0; i < n; i++){colIndex = getMaxNumberColIndexByRow(arr, i, n);maxRowNumber = arr[i][colIndex];minColNumber = getMinNumberByCol(arr, colIndex, n);if (maxRowNumber == minColNumber){isHaveSaddlePoint = 1;rowIndex = i;break;}}if (isHaveSaddlePoint){printf("%d %d\n", rowIndex, colIndex);}else{printf("NO\n");}
}

tips:这里为了方便测试将数组写死在程序了,你可以试着把这个改为用户输入。

** 思考**

  • 是否也可以先求每一列的最小数,让后判断该数是否是所在行最大的数呢?
  • 这里的算法复杂度O=n2 ,是否有算法复杂度为logn的算法呢?
  • 这里只求了一个鞍点,如果有多个鞍点时如何改进我们的算法使得可以计算多个鞍点呢?

测试样例:

2 1--------------------------------
Process exited after 0.1303 seconds with return value 0

转载于:https://www.cnblogs.com/simple-blog/p/9534037.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/249636.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue学习【第六篇】:Vue-cli脚手架(框架)与实战案例

环境搭建 安装node 官网下载安装包&#xff0c;傻瓜式安装&#xff1a;https://nodejs.org/zh-cn/ 安装cnpm npm install -g cnpm --registryhttps://registry.npm.taobao.org 安装脚手架 cnpm install -g vue/cli 清空缓存处理 npm cache clean --force 项目的创建 创建项目 v…

Docker安装配置教程

Docker安装配置教程

Python学习第十六篇——异常处理

在实际中&#xff0c;很多时候时候&#xff0c;我们并不能保证我们所写的程序是完美的。比如我们程序的本意是&#xff1a;用户在输入框内输入数字&#xff0c;并进行后续数学运算&#xff0c;即使我们提醒了用户需要输入数字而不是文本&#xff0c;但是有时会无意或者恶意输入…

cmd 常用命令

注&#xff1a;绿色的为比较常用的命令 命令名称ASSOC 显示或修改文件扩展名关联。ATTRIB显示或更改文件属性。BREAK 设置或清除扩展式 CTRLC 检查。CACLS显示或修改文件的访问控制列表(ACL)。BCDEDIT 设置启动数据库中的属性以控制启动加载。CALL从另一个批处理程序调用这一个…

js打字的效果

HTML代码&#xff1a; <div id"box"></div> javascript代码&#xff1a; var index 0; var word "8月6日美国的经济“制裁”如约而至&#xff0c;特朗普在社交网站发文称&#xff0c;对伊朗的制裁已经正式实施&#xff0c;他称这是“有史以来最激…

递归函数实现二分查找法

最初版本&#xff1a; 改进版&#xff1a; 最终版本&#xff1a; 递归实现阶乘&#xff1a; 转载于:https://www.cnblogs.com/www-qcdwx-com/p/10399288.html

图解LinkedHashMap原理

1 前言 LinkedHashMap继承于HashMap&#xff0c;如果对HashMap原理还不清楚的同学&#xff0c;请先看上一篇&#xff1a;图解HashMap原理 2 LinkedHashMap使用与实现 先来一张LinkedHashMap的结构图&#xff0c;不要虚&#xff0c;看完文章再来看这个图&#xff0c;就秒懂了…

02、体验Spark shell下RDD编程

02、体验Spark shell下RDD编程 1、Spark RDD介绍 RDD是Resilient Distributed Dataset&#xff0c;中文翻译是弹性分布式数据集。该类是Spark是核心类成员之一&#xff0c;是贯穿Spark编程的始终。初期阶段&#xff0c;我们可以把RDD看成是Java中的集合就可以了&#xff0c;在后…

CDH集群安装配置(四)- mysql 的安装

安装mysql&#xff0c;并且创建相关的表&#xff08;只需要在chd1上面安装而且需要root权限&#xff09;1.1 查看Centos自带mysql是否已经安装 yum list installed | grep mysql 卸载自带mariadb# rpm -qa | grep mariadb mariadb-libs-5.5.41-2.el7_0.x86_64 # rpm -e --nodep…

EF另一个 SqlParameterCollection 中已包含 SqlParameter。

代码&#xff1a; SqlParameter[] commandParameters new SqlParameter[]{new SqlParameter("CultID",filters.ParentID)};var result db.Database.SqlQuery<FM_PlantSolutions>("select s.* ,u.UserName as PrincipalName,isnull(ue.UserName,无) as E…

2019 GUDT RC 2 Problem C(题解)

原题 题目大意 这道题的背景是农夫和牛爬山,给出山的高度L,农夫会从山底以rF的速度爬山,中途不会休息,牛会从山底以rB的速度爬山,可以在休息站休息并吃草,在第i个休息站休息ti时间,牛可以吃t*ci的草,第i个休息站的高度为xi.农夫和牛同时出发,要求牛在不被农夫追上的同时吃最多的…

maven setting.xml 中文配置详解(全配置)

<?xml version"1.0" encoding"UTF-8"?> <!--| 官方文档: https://maven.apache.org/settings.html|| Maven 提供以下两种 level 的配置:|| 1. User Level. 当前用户独享的配置, 通常在 ${user.home}/.m2/settings.xml 目录下。 | …

String/Stringbuilder/StringBuffer

三个的运行速度&#xff1a;Stringbuilder>Stringbuffer>String String最慢是因为它是字符串常量&#xff0c;而其他两个是字符串变量。其中stringbuilder是非线程安全的、stringbuffer是线程安全的Stringbuilder适用于单线程且数据量大的字符串操作Stringbuffer适用于多…

CCF 差分约束--201809再卖菜

问题描述 在一条街上有n个卖菜的商店&#xff0c;按1至n的顺序排成一排&#xff0c;这些商店都卖一种蔬菜。   第一天&#xff0c;每个商店都自己定了一个正整数的价格。店主们希望自己的菜价和其他商店的一致&#xff0c;第二天&#xff0c;每一家商店都会根据他自己和相邻商…

Express + Element-ui 实现图片/文件上传

使用第三方插件 formidable 处理表单数据/文件 Express 4 以前&#xff0c;我们通常使用 req.files 来对请求中的文件进行处理&#xff0c;但在 Express 4 中这种用法已经被抛弃&#xff0c;默认情况下 req.files 在 req 对象上不再可用。官方推荐我们使用第三方中间件。 在这里…

weblogic12.1.3安装

weblogic weblogic12.1.3安装 环境&#xff1a; centos7.5 ip: 192.168.0.94 1、安装jdk 2、安装 weblogic 下载、解压安装包 wls1213_dev.zip unzip /application/weblogic12/wls1213_dev.zip mv wls12130 /application/weblogic12/ 配置环境变量 配置主机名解析 运行安装…

闭包那些事

定义&#xff1a; 在一个内部函数里&#xff0c; 对在外部作用域&#xff08;但不是在全局作用域&#xff09; 的变量进行引用&#xff0c; 那么内部函数就被认为是闭包&#xff08;closure&#xff09;。 例子&#xff1a; 1 def make_adder(addend):2 def adder(augend):3 …

10-04 矩形覆盖(斐波那契数列的应用)

题目描述&#xff1a; 我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形。请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形&#xff0c;总共有多少种方法&#xff1f; 解题思路与代码&#xff1a; 1&#xff09; 排列组合&#xff1a; class Solution { public:int rectC…

Spring 源码分析 spring-core

先来看下 spring-core 的包结构 总共有6个模块&#xff0c;分别是 asm、cglib、core、lang、objenesis、util asm包&#xff1a; 用来操作字节码&#xff0c;动态生成类或者增强既有类的功能。主要包含以下这些类。详细功能。 https://www.ibm.com/developerworks/cn/java/j…