《C程序设计》上机实验报告(五)之一维数组二维数组与字符数组

实验内容:

1.运行程序

#include <stdio.h>

void main( )

{ int i,j,iRow=0,iCol=0,m;

  int x[3][4]={{1,11,22,33},{2,28,98,38},{3,85,20,89}};

  m=x[0][0];

  for(i=0;i<3;i++) 

     for(j=0;j<4;j++)

         if (x[i][j]>m)

   {  m=x[i][j];

    iRow=i;

    iCol=j;

   }

  printf("%d,%d,%d\n",m,iRow,iCol);

}

要求:

(1)输入并调试上述源程序,对源程序进行编译、连接。

(2)运行并将结果填入表4-3。

(3)分析数组的定义、初始化过程以及程序的作用。

(4)将“if (x[i][j]>m)”改为“if (x[i][j]<m)”,再次编译、连接、运行程序,分析其功能及结果。

表4-3程序测试及结果分析

#include <stdio.h>

#include<string.h>

void main( )

{ char str1[80]={"Hefei"},str2[80]="Anhui";

  int i=0;

  while(str1[i]!='\0')

  {

   if(str1[i]>='a' && str1[i]<='z')

    str1[i]-=32;

   i++;

  }

  strcat(str1,str2);

  puts(str1);

}

要求:

(1)输入并调试上述源程序,对源程序进行编译、连接、运行。

(2)运行并将结果填入表4-4。

(3)分析数组的定义、初始化过程,比较str1和str2赋初值的差别。

(4)将while循环中的str1修改为str2的运行结果,分析循环的作用。

(5)写出判断字符数组结束的3种方法。

(6)列出所学的字符串处理函数,分析其功能。

表4-4 程序测试及结果分析

3. 程序填空

下面程序的功能是将二维数组所存储的矩阵a进行转置,并保存到数组b中。请在横线处填上正确的内容,以实现程序功能。

#include <stdio.h>

#include<string.h>

void main( )

{  int i,j;

   int a[4][3],b[3][4];

   for(i=0;i<4;i++) 

     for(j=0;j<3;j++)

        scanf("%d",&a[i][j]);

   for(i=0;i<4;i++) 

     for(j=0;j<3;j++)

                            

   for(                  )

   {

    printf("\n");

    for(j=0;j<4;j++)

         printf("%3d",b[i][j]);

   }

   printf("\n");

}

要求:

(1)输入并完善源程序,对源程序进行编译、连接。

(2)运行并将结果填入表4-5。

(3)如果a是方阵,比如4行4列,不定义数组b,如何实现转置?

表4-4 程序测试及结果分析

4.编写程序

编写一个程序,统计从键盘输入的10个字符,英文字母(不区分大小写)和数字(0~9)字符出现的次数。

程序:

int main()

{

 system("color f3");

 char c;

 int letters = 0, digit = 0;

 printf("请输入一行字符:");

 while ((c = getchar()) != '\n')

 {

  if (c >= 'a' && c <= 'z' || c >= 'A' && c <= 'Z')

  {

   letters++;

  }

  else if (c >= '0' && c <= '9')

  {

   digit++;

  }

 }

 printf("字母数:%d\n数字数:%d\n", letters, digit);

 return 0;

}

5.编写程序

输入一行字符,统计26个字母(不区分大小写)的个数。

程序:

int main()

{

    int i;

    int a[26] = { 0 }; // 计数

int b[26] = { 0 }; // 计数

  

  char c;

while ((c = getchar()) != '\n' && c != EOF)

    {

        if ((c >= 'A') && (c <= 'Z')) {

            a[c - 'A']++;

        }

        else if ((c >= 'a') && (c <= 'z')) {

            b[c - 'a']++;

        }

    }

    for (i = 0; i < 26; i++) {

        if (a[i] > 0)

            printf("%c:%d\n", i + 'A', a[i]);

        if (b[i] > 0)

            printf("%c:%d\n", i + 'a', b[i]);

    }

    return 0;

}

6.编写程序

编写一个程序,打印杨辉三角形的前7行,即输出:

1

1  1

1  2  1

1  3  3  1

1  4  6  4  1

1  5  10  10  5  1

1  6  15  20  15  6  1

要求及提示:

(2)先找出杨辉三角形中各行数的特点、行间数的关系,然后利用二维数组处理。

程序:

void main()

{

    system("color f3");

int a[7][7], i, j;

    for (i = 0; i < 7; i++)

    {

        a[i][0] = 1;

        a[i][i] = 1;

    }

    for (i = 2; i < 7; i++)

    {

        for (j = 1; j < i; j++)

        {

            a[i][j] = a[i - 1][j] + a[i - 1][j - 1];

        }

    }

    for (i = 0; i < 7; i++)

    {

        for (j = 0; j <= i; j++)

        {

            printf("%5d", a[i][j]);

        }

        printf("\n");

    }

}

7.编写程序

编写一个程序,求4×6整型矩阵的外围元素之和。

程序:

int main()

{

    system("color f3");

    int i = 0, j = 0;

    int a[4][6];

    printf("请输入4*6矩阵元素:\n");

    for (i = 0; i < 4; i++)

    {

        for (j = 0; j < 6; j++)

        {

            scanf_s("%d", &a[i][j]);

        }

    }

j = 5;

    int temp = 0;

    for (i = 0; i < 4; i++)

    {                          

        temp = temp + a[i][i] + a[i][j];

        j--;

    }

    printf("\n%d\n", temp);

    printf("\n4*4矩阵:\n");

    for (i = 0; i < 4; i++)

    {

        for (j = 0; j < 6; j++)

        {

            printf("%d ", a[i][j]);

        }

        printf("\n");

    }

    return 0;

}

   8.编写程序

已经一个班级有45个学生。用一个三列的二维数组存放学生的信息。第一列存放学号,第二列存放物理成绩,第三列存放数学成绩。要求编程实现:

1数学及物理课程的平均成绩。

2输出两门课程都低于平均成绩的同学的学号和成绩。

3对数学成绩从高到低排序。

程序:

#include<stdio.h>

int main()

{

    system("color f3");

    int a[3][3], i, j, b;

    float x, y;

    printf("输入学号,物理成绩,数学成绩:\n");

    for (i = 0; i < 3; i++)

    {

        for (j = 0; j < 3; j++)

            scanf_s("%d", &a[i][j]);

    }

x = (float)(a[0][1] + a[1][1] + a[2][1]) / 3;

    y = (float)(a[0][2] + a[1][2] + a[2][2]) / 3;

    printf("物理平均成绩为:%f\n数学平均成绩为:%f\n", x, y);

    for (i = 0; i < 3; i++)

    {

        if (a[i][1] < x && a[i][2] < y)

            printf("学号为%d的同学物理成绩为%d数学成绩为%d都低于平均成绩的\n", a[i][0], a[i][1], a[i][2]);

    }

    for (i = 0; i < 3; i++)

        if (a[i][2] < a[i + 1][2])

        {

            b = a[i][2]; a[i][2] = a[i + 1][2];

            a[i + 1][2] = b;

        }

    printf("数学成绩从高到低排序:");

    for (i = 0; i < 3; i++)

        printf("%d", a[i][2]);

    return 0;

}

9.编写程序

将一个二维数组行和列元素互换,存到另一个二维数组中。

   

程序:

int main()

{

    system("color f3");

    int i, j, a[2][3] = { {1,2,3},{4,5,6} }, b[3][2];

    printf("array a:\n");

    for (i = 0; i <= 1; i++)//处理a数组中的一行中各元素

    {

        for (j = 0; j <= 2; j++)//处理a数组中某一列元素

        {

            printf("%5d", a[i][j]);

            b[j][i] = a[i][j];

        }

printf("\n");

    }

    printf("array b:\n");

    for (i = 0; i <= 2; i++)

    {

        for (j = 0; j <= 1; j++)

        {

            printf("%5d", b[i][j]);

        }

        printf("\n");

    }

    return 0;

}

10.编写程序

求出4*4矩阵中最大和最小元素值及其所在行、列的行下标和列下标。再求出两条对角线元素之和。

程序:

int main()

{

    system("color f3");

    int sum = 0;

    int max, min;

    int max1, max2;//记录最大值的坐标

    int min1, min2;//记录最小值的坐标

    int i, j;

    int a[4][4];//为数组赋值

    for (i = 0; i < 4; i++)

    {

        for (j = 0; j < 4; j++)

        {

            scanf_s("%d", &a[i][j]);

        }

    }

max = min = a[0][0];//初始化最大值最小值都为数组的第一个元素值a[0][0]

    for (i = 0; i < 4; i++)

    {

        for (j = 0; j < 4; j++)

        {

            if (max <= a[i][j])//需要把=写上

{

                max = a[i][j];

                max1 = i, max2 = j;

            }

            if (min >= a[i][j])

            {

                min = a[i][j];

                min1 = i, min2 = j;

            }

        }

    }

    printf("%d %d\n", max, min);

    printf("max(%d,%d)  min(%d %d)\n", max1, max2, min1, min2);

    //求两条主对角线元素之和

    for (i = 0; i < 4; i++)

    {

        for (j = 0; j < 4; j++)

        {

            if (i == j || (i + j == 3))//关键(j==3-i)

                sum = sum + a[i][j];

        }

    }

    printf("sum=%d\n", sum);

    return 0;

}

程序测试及运行结果:

4.

5.

6.

7.

8.

.9.

10.

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

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

相关文章

Elasticsearch:将文档级安全性 (DLS) 添加到你的内部知识搜索

作者&#xff1a;来自 Elastic Sean Story 你的企业很可能淹没在内部数据中。 你拥有问题跟踪、笔记记录、会议记录、维基页面、视频录制、聊天以及即时消息和私信。 并且不要忘记电子邮件&#xff01; 难怪如此多的企业都在尝试创造工作场所搜索体验 - 为员工提供集中、一站…

react 之 UseReducer

UseReducer作用: 让 React 管理多个相对关联的状态数据 import { useReducer } from react// 1. 定义reducer函数&#xff0c;根据不同的action返回不同的新状态 function reducer(state, action) {switch (action.type) {case INC:return state 1case DEC:return state - 1de…

【飞书小技巧】——飞书文档转 markdown 详细教程

飞书文档转 markdown 详细教程 基于项目:https://github.com/Wsine/feishu2md 如何使用 在线版 访问 https://feishu2md.onrender.com/ 粘贴文档链接即可&#xff0c;文档链接可以通过 分享 > 开启链接分享 > 复制链接 获得。 点击下载之后,会提示 Please wait. It ma…

2024/2/1学习记录

echarts 为柱条添加背景色&#xff1a; 若想设置折线图的点的样式&#xff0c;设置 series.itemStyle 指定填充颜色就好了&#xff0c;设置线的样式设置 lineStyle 就好了。 在折线图中倘若要设置空数据&#xff0c;用 - 表示即可&#xff0c;这对于其他系列的数据也是 适用的…

【C/C++】C/C++编程——整型(二)

在 C 中&#xff0c;整型数据可以分为有符号数&#xff08;Signed&#xff09;和无符号数&#xff08;Unsigned&#xff09;&#xff0c;这两种类型主要用于表示整数值&#xff0c;但它们在表示范围和用途方面有所不同。默认情况下&#xff0c;整数类型如 int、short、long 都是…

中科大计网学习记录笔记(三):接入网和物理媒体

前言&#xff1a; 学习视频&#xff1a;中科大郑烇、杨坚全套《计算机网络&#xff08;自顶向下方法 第7版&#xff0c;James F.Kurose&#xff0c;Keith W.Ross&#xff09;》课程 该视频是B站非常著名的计网学习视频&#xff0c;但相信很多朋友和我一样在听完前面的部分发现信…

开发中常用的数据结构

在软件开发中&#xff0c;常用的数据结构具有各自的场景和应用。以下是一些常见的数据结构、它们的应用场景以及相应的代码示例&#xff1a; 数组&#xff08;Array&#xff09;: 场景&#xff1a;用于存储一组相同类型的元素&#xff0c;通过索引访问元素。例子&#xff1a;le…

深度学习如何入门?

深度学习是一个广泛而深入的领域&#xff0c;入门可能看起来有些令人望而却步。然而&#xff0c;通过有条理地学习基础知识和逐步实践&#xff0c;您可以有效地掌握深度学习。以下是入门深度学习的建议步骤&#xff1a; 1. 强化基础知识 数学基础&#xff1a;深入学习线性代数…

Shell - 学习笔记 - 2.8 - Shell字符串详解

字符串&#xff08;String&#xff09;就是一系列字符的组合。字符串是 Shell 编程中最常用的数据类型之一&#xff08;除了数字和字符串&#xff0c;也没有其他类型了&#xff09;。 字符串可以由单引号 包围&#xff0c;也可以由双引号" "包围&#xff0c;也可以不…

学术名词积累和解释(机器人感知,运动规划,控制领域)——那些没人告诉你的专用名词

背景和初衷&#xff1a; 刚入门的学术小白们在阅读文献的过程中&#xff0c;总会遇到一些默生涩难懂但是通用的学术名词。例如什么 proactive and reactive, nonholonomic and holonomic 。 这里为了方便大家&#xff0c;总结和解释自己阅读学术文章过程中遇到的机器人领域的相…

2024-02-01 思考-关于商业思维和技术实现之间的关系

摘要: 最近在持续的进行商业推动&#xff0c;对于商业行为之下&#xff0c;与技术实现之间的关系&#xff0c;有了更为深刻的认知。 本文做下简单的记录。 商业思维: 什么是商业思维&#xff1f;很有意思的问题&#xff0c;好像除了商业思维&#xff0c;还有一堆其他迥然相反…

基于tidevice实现iOS app自动化使用详解

目录 1、IOS自动化工具概述 2、tidevice工具的原理和使用 2.1、tidevice的原理 2.2、tidevice实现的功能 2.3、tidevice的安装 2.4、tidevice的使用 2.4.1、设备管理 1、查看已连接的设备的列表 2、检测设备连接状态 3、等待设备连接&#xff0c;只要有就连接就结束监…

滑动一整屏

需求&#xff1a;用户通过鼠标滚轮滑动的时候一整屏进行翻页。 参考网站效果 微派网络 实现思路&#xff1a; 1.首先我们需获取可视区域的高度 document.documentElement.clientHeight; 2.根据动态设置top属性即可进行翻页。 3.需判断上滑还是下滑 根据onmousewheel滚轮事…

2024-01-06-AI 大模型全栈工程师 - 如何训练百亿参数大模型

摘要 2024-01-06 周六 杭州 晴 本节内容: 讲座模式&#xff0c;学习大模型训练的相关流程。 课程内容 1. Transformer 回顾 2. 模型架构-生成式 3. 预训练数据的构建 4. 中文字典的构建 4. 预训练目标的构建 5. 预训练相关-预训练策略 6. 预训练相关-并行化训练 7. 预训练…

2024/2/1 备战蓝桥杯 3-3 二叉树

目录 二叉树的遍历 B3642 二叉树的遍历 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 完全二叉树的权值 0完全二叉树的权值 - 蓝桥云课 (lanqiao.cn) 美国血统 American Heritage P1827 [USACO3.4] 美国血统 American Heritage - 洛谷 | 计算机科学教育新生态 (luogu.c…

搭建高效企业培训平台:教育系统源码开发详解

为了更好地满足企业培训的需求&#xff0c;许多组织纷纷转向数字化教育&#xff0c;搭建高效的企业培训平台成为当务之急。本篇文章&#xff0c;小编将为您讲解教育系统源码的开发细节&#xff0c;为搭建一个功能强大、灵活高效的企业培训平台提供详尽的指南。 一、教育系统的…

Django响应(一)

一、HttpResponse与JsonResponse 1.1、HttpResponse 官网:https://docs.djangoproject.com/zh-hans/4.1/ref/request-response/#django.http.HttpResponse 返回给浏览器端的响应对象 from django.http import HttpResponse response = HttpResponse("Heres the text o…

程序的内存模型

师从黑马程序员 内存分区模型 内存大方向划分为4个区域 1、代码区&#xff1a;存放函数体的二进制代码&#xff0c;由操作系统管理的 2、全局区&#xff1a;存放全局变量环和静态变量以及常量 3、栈区&#xff1a;由编译器自动分配释放&#xff0c;存放函数的参数值&#…

代码随想录算法训练营第三十六天|509. 斐波那契数 70. 爬楼梯 746. 使用最小花费爬楼梯

509. 斐波那契数 public static int fib(int n) {// 找出最后一步// 定义损失函数 定义记忆化存储基本单元// 状态转移方程 f(n) f(n-2)f(n-1); n > 0// 边界 (递归过程中需要判断)// 初始化 (在未递归之前需要处理)// 返回答案if (n 0) {return 0;}if (n 1) {return 1;…

H12-811_503

503.如下图所示&#xff0c;下列说法正确是&#xff1f;( ) A.主机A和主机B的广播地址相同 B.主机A可以ping通主机B C.主机A和主机B不能获取对方的MAC地址 D.主机A的ARP缓存中存在如下条目10.0.12.5 MAC-B 答案&#xff1a;C 注释&#xff1a; 两个主机IP地址的网…