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

11.20作业

题目一:

题目:

// 数组的行列转置

代码:

// 数组的行列转置
#include <stdio.h>
int main()
{int a[2][3], i, j, b[3][2];printf("输入一个两行三列的数组a:\n");for (i = 0; i < 2; i++)for (j = 0; j < 3; j++){scanf("%d", &a[i][j]);}for (i = 0; i < 2; i++)for (j = 0; j < 3; j++){b[j][i] = a[i][j];}printf("转置后得到的一个三行两列的数组b:\n");for (i = 0; i < 3; i++){for (j = 0; j < 2; j++){printf("%d\t", b[i][j]);}printf("\n");}
}

题目二:

题目:

// 打印杨辉三角

代码:

#define N 11
#include <stdio.h>
int main()
{int i, j, a[N][N];for (i = 1; i < N; i++){a[i][i] = 1;a[i][1] = 1;}for (i = 3; i < N; i++){for (j = 2; j <= i - 1; j++){a[i][j] = a[i - 1][j - 1] + a[i - 1][j];}}for (i = 1; i < N; i++){for (j = 1; j <= i; j++){printf("%d\t", a[i][j]);}printf("\n");}printf("\n");
}

题目三:

题目:

// 数组对角线元素求和

代码:

#include <stdio.h>
#define N 3
int main()
{int a[N][N];int i, j, sum = 0;printf("输入%d行%d列的数组:\n", N, N);for (i = 0; i < N; i++){for (j = 0; j < N; j++){scanf("%d", &a[i][j]);}}for (i = 0; i < N; i++){sum = sum + a[i][i] + a[i][N - 1 - i];}if (N % 2 != 0){sum = sum - a[N / 2][N / 2];}printf("对角线元素求和为:%d",sum);
}

 

题目四:

题目:

//求 主对角线元素的最大值 主对角线元素的积 主对角线元素的平方和

代码:

//求 主对角线元素的最大值 主对角线元素的积 主对角线元素的平方和
#include <stdio.h>
#define N 3
int main()
{int a[N][N];int i, j, sum = 0, max, p = 1, sqSum = 0;printf("输入%d行%d列的数组:\n", N, N);for (i = 0; i < N; i++){for (j = 0; j < N; j++){scanf("%d", &a[i][j]);}}max = a[0][0];for (i = 0; i < N; i++){
//主对角线元素的最大值if (a[i][i] > max){max = a[i][i];}//主对角线元素的积p = p * a[i][i];//主对角线元素的平方和sqSum = sqSum + a[i][i] * a[i][i];}printf("主对角线元素的最大值: %d\n", max);printf("主对角线元素的积: %d\n", p);printf("主对角线元素的平方和: %d\n", sqSum);
}

 

题目五:

题目:

//找出5个数中的最小值

代码:

//找出5个数中的最小值
#include <stdio.h>int min(int x, int y) {return (x < y ? x : y);   //condition ? expression1(true) : expression2(false);
}int main() {int a[5], i, m;printf("输入五个数:");for (i = 0; i < 5; i++) {scanf("%d", &a[i]);}m = a[0];for (i = 1; i < 5; i++) {m = min(m, a[i]);}printf("最小值为:%d\n", m);return 0;
}

 

题目六:

题目:

//定义了一个二维数组score,用于存储10个学生4门课程的成绩,打印出每个学生的索引和他们的成绩总和

代码:

//定义了一个二维数组score,用于存储10个学生4门课程的成绩,打印出每个学生的索引和他们的成绩总和#include <stdio.h>int sum(int x, int y, int z) {return (x + y + z);
}int main() {int score[5][4], i, j;// 输入每个学生的三门成绩printf("依次输入每个学生的三门课程成绩:\n");for(i = 0; i < 5; i++) {for(j = 1; j < 4; j++) {scanf("%d", &score[i][j]);}// 计算总分并存储在 score[i][0]score[i][0] = sum(score[i][1], score[i][2], score[i][3]);}// 输出每个学生的编号及其总分for(i = 0; i < 5; i++) {printf("Student %d: Total Score = %d\n", i + 1, score[i][0]);}return 0;
}

题目七:

题目:

//计算数组中每个元素的第 k 位数字之和

代码:

//计算数组中每个元素的第 k 位数字之和#define N 10
#include<stdio.h>
int fun(int n, int k) {int i;for (i = 1; i <= k - 1; i++) {n = n / 10;n = n % 10;}return n;
}int main() {int a[N], k, i, sum = 0;printf("输入十个数:\n");for (i = 0; i < N; i++) {scanf("%d", &a[i]);}printf("Input k:\n");scanf("%d", &k);for (i = 0; i < N; i++) {sum += fun(a[i], k);}printf("The k sum is %d\n", sum);return 0;
}

题目八:

题目:

//用冒泡排序算法对数组进行排序,并在排序前后打印数组

代码:

//用冒泡排序算法对数组进行排序,并在排序前后打印数组
#include<stdio.h>void sort(int b[], int n) {int i, j, t;for (i = 1; i < n; i++) {for (j = 0; j < n - i; j++) {if (b[j] > b[j + 1]) {t = b[j];b[j] = b[j + 1];b[j + 1] = t;}}}
}void printarr(int b[], int n) {int i;for (i = 0; i < n; i++)printf("%5d", b[i]);printf("\n");
}int main() {int a[10] = {11, 12, 63, 97, 58, 80, 48, 32, 73, 36};printf("Before sort:\n");printarr(a, 10);sort(a, 10);printf("After sort:\n");printarr(a, 10);return 0;
}

代码优化:

#include <stdio.h>void sort(int b[], int n) {int i, j, t;int swapped;for (i = 0; i < n - 1; i++) {  // 外层循环控制排序的轮数swapped = 0;  // 记录这一轮是否有交换for (j = 0; j < n - 1 - i; j++) {  // 内层循环进行相邻元素比较if (b[j] > b[j + 1]) {t = b[j];b[j] = b[j + 1];b[j + 1] = t;swapped = 1;  // 如果发生交换,则标记为 1}}if (!swapped) {  // 如果这一轮没有交换,数组已经有序,提前退出break;}}
}void printarr(int b[], int n) {int i;for (i = 0; i < n; i++)printf("%5d", b[i]);  // 每个数字占5个字符宽度printf("\n");
}int main() {int a[10] = {11, 12, 63, 97, 58, 80, 48, 32, 73, 36};printf("Before sort:\n");printarr(a, 10);sort(a, 10);printf("After sort:\n");printarr(a, 10);return 0;
}

 

http://www.lryc.cn/news/488142.html

相关文章:

  • Ubuntu Linux使用前准备动作_使用root登录图形化界面
  • DICOM核心概念:显式 VR(Explicit VR)与隐式 VR(Implicit VR)在DICOM中的定义与区别
  • 源码分析Spring Boot (v3.3.0)
  • IPv6 NDP 记录
  • linux常用命令(文件操作)
  • 内存管理 I(内存管理的基本原理和要求、连续分配管理方式)
  • 【Redis】基于Redis实现秒杀功能
  • Hadoop 使用过程中 15 个常见问题的详细描述、解决方案
  • 【Flutter 问题系列第 84 篇】如何清除指定网络图片的缓存
  • 【UE5】使用基元数据对材质传参,从而避免新建材质实例
  • 鸿蒙动画开发07——粒子动画
  • IDEA2023 创建SpringBoot项目(一)
  • VSCode:终端打开一片空白,无cmd
  • Zea maize GO
  • Android开发实战班 - 数据持久化 - 数据加密与安全
  • EDA实验设计-led灯管动态显示;VHDL;Quartus编程
  • Eclipse 查找功能深度解析
  • 第三百二十九节 Java网络教程 - Java网络UDP套接字
  • Leetcode215. 数组中的第K个最大元素(HOT100)
  • QT与嵌入式——搭建串口
  • Shell编程-6
  • 使用 Postman 设置 Bearer Token 进行身份验证
  • 现在转前端怎么样?
  • 【算法一周目】滑动窗口(1)
  • React Native 基础
  • 【C++笔记】list使用详解及模拟实现
  • 【机器学习】机器学习中用到的高等数学知识-7.信息论 (Information Theory)
  • 《现代制造技术与装备》是什么级别的期刊?是正规期刊吗?能评职称吗?
  • 09 - Clickhouse的SQL操作
  • 如何解决pdf.js跨域从url动态加载pdf文档