当前位置: 首页 > news >正文

《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.

相关文章:

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

实验内容&#xff1a; 1.运行程序 #include <stdio.h> void main( ) { int i,j,iRow0,iCol0,m; int x[3][4]{{1,11,22,33},{2,28,98,38},{3,85,20,89}}; mx[0][0]; for(i0;i<3;i) for(j0;j<4;j) if (x[i][j]>m) { mx[i][j]; iRowi…...

【BUG】联想Y7000电池电量为0且无法充电解决方案汇总

因为最近火灾很多&#xff0c;所以昨天夜晚睡觉的时候把插线板电源关掉了&#xff0c;电脑也关机了。 各位一定要注意用电安全&#xff0c;网上的那些事情看着真的很难受qvq。 第二天早上起床的时候一看发现电脑直接没电了&#xff0c;插上电源后也是显示 你一定要冲进去啊(ू˃…...

centos7常用命令之安装插件2

centos7安装插件1 7、kibana 【启动kibana,需要调整这个配置文件(/opt/kibana-6.3.0/config/kibana.yml)的一处ip地址,因为每次虚拟机的ip地址可能会有所不同&#xff0c; 同时访问页面地址的ip:5601时,ip地址也对应修改】 1.解压缩包 cd /opt/ tar -xvf kibana-6.3.0-linux-x…...

MATLAB - 仿真单摆的周期性摆动

系列文章目录 前言 本例演示如何使用 Symbolic Math Toolbox™ 模拟单摆的运动。推导摆的运动方程&#xff0c;然后对小角度进行分析求解&#xff0c;对任意角度进行数值求解。 一、步骤 1&#xff1a;推导运动方程 摆是一个遵循微分方程的简单机械系统。摆最初静止在垂直位置…...

Pandas进阶--map映射,分组聚合和透视pivot_table详解

文章目录 1.Pandas的map映射&#xff08;1&#xff09;映射&#xff08;2&#xff09;map充当运算工具 2.数据分组和透视&#xff08;1&#xff09;分组统计 - groupby功能 是pandas最重要的功能&#xff08;2&#xff09;聚合agg 3.透视表pivot_table&#xff08;1&#xff09…...

Visual Studio 和Clion配置Cocos2d-x环境

Visual Studio 和Clion配置Cocos2d-x环境 我就不贴图片的&#xff0c;懒得上传图床。懒。开发环境: ​ 系统: Window11 ​ 编译器: CMake MSVC ​ 开发工具&#xff1a;Clion or Visual Studio ​ 请自行配置好&#xff0c;Python2.7&#xff0c;和Cmake ​ Cocos2d-x下载…...

【百度Apollo】本地调试仿真:加速自动驾驶系统开发的利器

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《linux深造日志》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! ⛳️ 推荐 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下…...

ztest中ddof起什么作用

⭐️ statsmodels 中 ztest 基本使用 statsmodels 也是一个强大的统计分析库&#xff0c;提供了丰富的统计模型和检验功能。对于 Z 检验&#xff0c;statsmodels 提供了 ztest 函数。 以下是使用 statsmodels 进行 Z 检验的示例&#xff1a; from statsmodels.stats.weights…...

linux 主机无法联网问题

主机不能联网 一 查看当前ip ping路由 ifconfig wlan0 wlan0: flags4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500inet 192.168.2.78 netmask 255.255.255.0 broadcast 192.168.2.255ping 192.168.2.1查看是否能ping通 二 查看路由表 route -n Destination G…...

2024/1/27 备战蓝桥杯 1-1

目录 求和 0求和 - 蓝桥云课 (lanqiao.cn) 成绩分析 0成绩分析 - 蓝桥云课 (lanqiao.cn) 合法日期 0合法日期 - 蓝桥云课 (lanqiao.cn) 时间加法 0时间加法 - 蓝桥云课 (lanqiao.cn) 扫雷 0扫雷 - 蓝桥云课 (lanqiao.cn) 大写 0大写 - 蓝桥云课 (lanqiao.cn) 标题…...

支持下一代网络IpV6的串口服务器,IpV6串口485接口转网口

和IPv4比较&#xff0c;IPv6有两个极具吸引力的特点&#xff1a;一个是IPv6采用的128位地址格式&#xff0c;而IPv4采用32位的地址格式&#xff0c;因此IPv6使地址空间增大了296&#xff1b;另一个是IPv6物联网数据业务具有更强的支持能力&#xff0c;成为未来物联网的重要协议…...

uniapp H5 实现上拉刷新 以及 下拉加载

uniapp H5 实现上拉刷新 以及 下拉加载 1. 先上图 下拉加载 2. 上代码 <script>import DragableList from "/components/dragable-list/dragable-list.vue";import {FridApi} from /api/warn.jsexport default {data() {return {tableList: [],loadingHi…...

网络工程师必学知识:2、IPv4和IPv6地址划分

网络工程师必学知识&#xff1a;2、IPv4和IPv6地址划分 1.概述&#xff1a;2.IPv4&#xff1a;地址划分&#xff1a;有类划分&#xff0c;无类划分。一、有类划分&#xff1a;分为5类。ABCDE&#xff0c;掩码分别位8、16、24、28、27取值范围&#xff1a;出类别bit不变&#xf…...

Rust - 变量

不管学什么语言好像都得从变量开始&#xff0c;不过只需要懂得大概就可以了。 但在Rust里不先把变量研究明白后面根本无法进行… 变量绑定 变量赋值❌ 变量绑定✔️ Rust中没有“赋值”一说&#xff0c;而是称为绑定。 int a 3; //C中的变量赋值 a 3; //python中的…...

【Linux】压缩脚本、报警脚本

一、压缩搅拌 要求&#xff1a; 写一个脚本&#xff0c;完成如下功能 传递一个参数给脚本&#xff0c;此参数为gzip、bzip2或者xz三者之一&#xff1b; (1) 如果参数1的值为gzip&#xff0c;则使用tar和gzip归档压缩/etc目录至/backups目录中&#xff0c;并命名为/backups/etc…...

用Flask打造一个大模型智能问答WEB网站

目前已经有很多类似GPT的大模型开源,可以提供类似ChatGPT的智能问答功能。我也基于这些开源模型,用Flask来建立一个智能问答网站,可以方便用户建立自己的ChatGPT系统。 这个网站需要提供用户登录功能,对已登录的用户,可以在网站上提出问题,并由大模型处理后返回答案。演…...

学习python第三天

一.数据类型 1.获取数据类型 x 10 print(type(x))""" 输出 <class int> """2.复数类型&#xff08;complex&#xff09;详解 复数&#xff08;Complex&#xff09;是 Python 的内置类型&#xff0c;直接书写即可。换句话说&#xff0c…...

(M)UNITY三段攻击制作

三段攻击逻辑 基本逻辑&#xff1a; 人物点击攻击按钮进入攻击状态&#xff08;bool isAttack&#xff09; 在攻击状态下&#xff0c; 一旦设置的触发器&#xff08;trigger attack&#xff09;被触发&#xff0c;设置的计数器&#xff08;int combo&#xff09;查看目前攻击…...

PHP的线程安全与非线程安全模式选哪个

曾经初学PHP的时候也很困惑对线程安全与非线程安全模式这块环境的选择&#xff0c;也未能理解其中意。近来无意中看到一个教程对线程安全&#xff08;饿汉式&#xff09;&#xff0c;非线程安全&#xff08;懒汉式&#xff09;的描述&#xff0c;虽然觉得现在已经能够很明了透彻…...

asdf安装不同版本的nodejs和yarn和pnpm

安装asdf 安装nodejs nodejs版本 目前项目中常用的是14、16和18 安装插件 asdf plugin add nodejs https://github.com/asdf-vm/asdf-nodejs.git asdf plugin-add yarn https://github.com/twuni/asdf-yarn.git可以查看获取所有的nodejs版本 asdf list all nodejs有很多找…...

SkyWalking 10.2.0 SWCK 配置过程

SkyWalking 10.2.0 & SWCK 配置过程 skywalking oap-server & ui 使用Docker安装在K8S集群以外&#xff0c;K8S集群中的微服务使用initContainer按命名空间将skywalking-java-agent注入到业务容器中。 SWCK有整套的解决方案&#xff0c;全安装在K8S群集中。 具体可参…...

【杂谈】-递归进化:人工智能的自我改进与监管挑战

递归进化&#xff1a;人工智能的自我改进与监管挑战 文章目录 递归进化&#xff1a;人工智能的自我改进与监管挑战1、自我改进型人工智能的崛起2、人工智能如何挑战人类监管&#xff1f;3、确保人工智能受控的策略4、人类在人工智能发展中的角色5、平衡自主性与控制力6、总结与…...

spring:实例工厂方法获取bean

spring处理使用静态工厂方法获取bean实例&#xff0c;也可以通过实例工厂方法获取bean实例。 实例工厂方法步骤如下&#xff1a; 定义实例工厂类&#xff08;Java代码&#xff09;&#xff0c;定义实例工厂&#xff08;xml&#xff09;&#xff0c;定义调用实例工厂&#xff…...

用docker来安装部署freeswitch记录

今天刚才测试一个callcenter的项目&#xff0c;所以尝试安装freeswitch 1、使用轩辕镜像 - 中国开发者首选的专业 Docker 镜像加速服务平台 编辑下面/etc/docker/daemon.json文件为 {"registry-mirrors": ["https://docker.xuanyuan.me"] }同时可以进入轩…...

html-<abbr> 缩写或首字母缩略词

定义与作用 <abbr> 标签用于表示缩写或首字母缩略词&#xff0c;它可以帮助用户更好地理解缩写的含义&#xff0c;尤其是对于那些不熟悉该缩写的用户。 title 属性的内容提供了缩写的详细说明。当用户将鼠标悬停在缩写上时&#xff0c;会显示一个提示框。 示例&#x…...

2023赣州旅游投资集团

单选题 1.“不登高山&#xff0c;不知天之高也&#xff1b;不临深溪&#xff0c;不知地之厚也。”这句话说明_____。 A、人的意识具有创造性 B、人的认识是独立于实践之外的 C、实践在认识过程中具有决定作用 D、人的一切知识都是从直接经验中获得的 参考答案: C 本题解…...

Aspose.PDF 限制绕过方案:Java 字节码技术实战分享(仅供学习)

Aspose.PDF 限制绕过方案&#xff1a;Java 字节码技术实战分享&#xff08;仅供学习&#xff09; 一、Aspose.PDF 简介二、说明&#xff08;⚠️仅供学习与研究使用&#xff09;三、技术流程总览四、准备工作1. 下载 Jar 包2. Maven 项目依赖配置 五、字节码修改实现代码&#…...

R语言速释制剂QBD解决方案之三

本文是《Quality by Design for ANDAs: An Example for Immediate-Release Dosage Forms》第一个处方的R语言解决方案。 第一个处方研究评估原料药粒径分布、MCC/Lactose比例、崩解剂用量对制剂CQAs的影响。 第二处方研究用于理解颗粒外加硬脂酸镁和滑石粉对片剂质量和可生产…...

Netty从入门到进阶(二)

二、Netty入门 1. 概述 1.1 Netty是什么 Netty is an asynchronous event-driven network application framework for rapid development of maintainable high performance protocol servers & clients. Netty是一个异步的、基于事件驱动的网络应用框架&#xff0c;用于…...

Go 并发编程基础:通道(Channel)的使用

在 Go 中&#xff0c;Channel 是 Goroutine 之间通信的核心机制。它提供了一个线程安全的通信方式&#xff0c;用于在多个 Goroutine 之间传递数据&#xff0c;从而实现高效的并发编程。 本章将介绍 Channel 的基本概念、用法、缓冲、关闭机制以及 select 的使用。 一、Channel…...