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

三、c语言练习四题

在这个系列中,我将以每次五题的形式加强对C语言的理解


1、 矩阵转置

要求

输入:

2 3
1 2 3
4 5 6

输出:

1 4 
2 5 
3 6 

//矩阵转置(复习)
int main()
{int i = 0;int j = 0;int arr[10][10];/*提前定义好一个大容量数组,因为VS不支持变长数组*/int m = 0;int n = 0;scanf("%d %d", &m, &n);for (i = 0;i < m;i++){for (j = 0;j < n;j++){scanf("%d", &arr[i][j]);}}for (i = 0;i < n;i++){for (j = 0;j < m;j++){printf("%d", arr[j][i]);/*将i和j互换就是打印的时候从列开始*/}printf("\n");}return 0;
}

这里需要注意的就是转置时列和行的互换,转置前是从行开始,转置后是先从列开始打印

在转置的第二个for循环中,此时才刚刚开始产生j并且实现范围内的自增,这时就能实现从列开始打印

2、计算Sn的值

Sn = a + aa + aaa + aaaa+ aaaaa,   输入a

int main()
{int i = 0;int sum = 0;int count = 1;scanf("%d", &i);while (count <= 10000){/*这里的错误是计算成了:2*1 + 2*10 + 2*100...*/
//而题目计算的是  2 + 22 + 222...sum += i * count;count *= 10;}printf("%d", sum);return 0;
}

在这里我出现了典型的错误,具体如图片中所展现的

下面是找到问题后改正的代码:

//Sn加和
int main()
{int i = 0;int sum = 0;int count = 0;scanf("%d", &i);int term = i;while (count < 5){/*这里的错误是计算成了:2*1 + 2*10 + 2*100...*/
//而题目计算的是  2 + 22 + 222...sum += term;term = term * 10 + i;count++;}printf("%d", sum);return 0;
}

如果还是while循环的话使用递推公式是最好的选择,它最重要的作用就是可以避免加和时i变化式子改变的影响                                        (简单说就是保留了i输入后的起始值)

还有一种是用for循环来处理,是更清晰的处理方法:

//这是改进后的代码
int main()
{int i = 0;int sum = 0;int a = 0;int j = 0;scanf("%d %d", &i, &a);int term = 0;for (j = 0;j < a;j++){term = term * 10 + i;sum += term;}printf("%d", sum);return 0;
}

3、打印菱形(如图所示)

      ************************************
*************************************************

像这种打印图形的题目都有一个通法,那就是将他们的数据一一列出来然后寻找算数上的规律,

最后按照规律打印它们即可:

//题目 打印菱形void fun(int line, int under)
{int i = 0;int j = 0;int k = 0;int m = 0;int n = 0;int o = 0;/*打印上半部分,一行一行打印*/for (i = 0;i < line;i++){/*先打印空格*/for (j = 0;j < line - 1 - i;j++){printf(" ");}for (k = 0;k < 2 * i + 1;k++){printf("*");}printf("\n");}for (m = 0;m < under;m++){for (n = 0;n < m + 1;n++){printf(" ");}for (o = 0;o < (under - m) * 2 - 1;o++){printf("*");}printf("\n");}
}int main()
{fun(7, 6);return 0;
}

4、递归在阶乘上的实现

//一、递归在阶乘上的实现
Rat(int i)
{if (i == 0)/*限制条件*/return 1;else/*每一次递归都接近这个限制条件*/return Rat(i - 1) * i;
}int main()
{int i = 0;scanf("%d", &i);int a = Rat(i);printf("%d", a);return 0;
}

这是一种递归的方法,当然也可以不使用递归来做

方法如下:

int main()
{int a = 0;int m = 0;int sum = 0;for (a = 1; a <= 10;a++){int ret = 1;for (m = 1;m <= a;m++){ret *= m;}sum += ret;}printf("%d", sum);return 0;
}

当然,这里是为了方便调试而写了两个循环,可以想想一个循环可以实现嘛?

http://www.xdnf.cn/news/392077.html

相关文章:

  • Linux网络编程实现FTP服务器
  • 探秘 Cursor 核心:解锁系统提示词的进阶之路
  • c++ 如何写类(不带指针版)
  • k8s 资源对比总结
  • 精讲C++四大核心特性:内联函数加速原理、auto智能推导、范围for循环与空指针进阶
  • vue数据可视化开发echarts等组件、插件的使用及建议-浅看一下就行
  • 什么是硬件中断请求号?什么是中断向量号?
  • 英语复习笔记 1
  • Nipype使用:从安装配置到sMRI处理
  • 基于OpenCV的人脸识别:LBPH算法
  • MySQL数据库的安全性防护
  • 【问题】Watt加速github访问速度:好用[特殊字符]
  • 在 C++中,指针数组与数组指针的区别
  • 0基础 | L298N电机驱动模块 | 使用指南
  • 【基于 LangChain 的异步天气查询5】多轮对话天气智能助手
  • js的基本数据类型
  • opencascade.js stp vite 调试笔记
  • 使用 Java 反射动态加载和操作类
  • Ollama部署使用以及模型微调和本地部署
  • go语言对Cookie的支持
  • el-date-picker的type为daterange时仅对开始日期做限制
  • 【Java】线程实例化 线程状态 线程属性
  • AUTOSAR图解==>AUTOSAR_TR_HWTestManagementIntegrationGuide
  • REST/SOAP 协议介绍及开发示例
  • web animation API 锋利的css动画控制器 (更新中)
  • Python高级爬虫之JS逆向+安卓逆向2.1节: 网络爬虫核心原理
  • 【c++】【数据结构】二叉搜索树详解
  • InnoDB引擎
  • JVM规范之运行时数据区域
  • 【沉浸式求职学习day36】【初识Maven】