C++ 基础速通【数组】Ac-Wing

2024-09-03 19:28
文章标签 基础 c++ 数组 速通 ac wing

本文主要是介绍C++ 基础速通【数组】Ac-Wing,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数组替换

在这里插入图片描述

#include <iostream>
#include <cstdio>
using namespace std;
int main(){for(int i = 0; i < 10; i ++ ){int x;  cin >> x;printf("X[%d] = %d\n", i, x <= 0 ? 1 : x);}return 0;
}

数组中的行

在这里插入图片描述

#include <iostream>using namespace std;int main()
{int l;char op;cin >> l >> op;double s=0;for(int i=0;i<12;i++){for(int j=0;j<12;j++){double a;cin >> a;if(i==l) s+=a;}}printf("%.1lf",op=='S' ? s : s/12);
}

数组的右上半部分

在这里插入图片描述

#include <iostream>
using namespace std;
double m, s;//m用来读入,s用来计算和
char op;
int main()
{cin >> op;for (int i = 0; i < 12; i ++)for (int j = 0; j < 12; j ++){cin >> m;//重复读入mif (i < j)s += m;}if (op == 'S')printf("%.1lf", s);else printf("%.1lf", s / 66);return 0;
}

数组的左上半部分

在这里插入图片描述

#include <iostream>
using namespace std;
double m, s;//m用来读入,s用来计算和
char op;
int main()
{cin >> op;for (int i = 0; i < 12; i ++)for (int j = 0; j < 12; j ++){cin >> m;//重复读入mif (i+j<11)s += m;}if (op == 'S')printf("%.1lf", s);else printf("%.1lf", s / 66);return 0;
}

数组的上方区域

在这里插入图片描述

#include <iostream>
using namespace std;
double m, s;//m用来读入,s用来计算和
char op;
int main()
{cin >> op;for (int i = 0; i < 12; i ++)for (int j = 0; j < 12; j ++){cin >> m;//重复读入mif (i<j&&i+j<11)s += m;}if (op == 'S')printf("%.1lf", s);else printf("%.1lf", s / 30);return 0;
}

数组的左方区域

在这里插入图片描述

#include <iostream>
using namespace std;
double m, s;//m用来读入,s用来计算和
char op;
int main()
{cin >> op;for (int i = 0; i < 12; i ++)for (int j = 0; j < 12; j ++){cin >> m;//重复读入mif (i>j&&i+j<11)s += m;}if (op == 'S')printf("%.1lf", s);else printf("%.1lf", s / 30);return 0;
}

平方矩阵 I

在这里插入图片描述
在这里插入图片描述

  • 作者:小张同学
    链接:https://www.acwing.com/solution/content/9554/
    来源:AcWing
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

平方矩阵 II

在这里插入图片描述
在这里插入图片描述

#include <iostream>
using namespace std;
const int N = 110;
int a[N][N];int main()
{int n;cin >> n;while (n){for (int i = 0; i < n; i++){a[i][0] = i + 1;//第一行a[0][i] = i + 1;//第一列}for (int i = 1; i < n; i++){for (int j = 1; j < n; j++){a[i][j] = a[i - 1][j - 1];//其他位置,a[i][j] = a[i - 1][j - 1]}}for (int i = 0; i < n; i++)//输出矩阵{for (int j = 0; j < n; j++){cout << a[i][j] << " ";}cout << endl;}cout << endl;cin >> n;}
}作者:Hasity
链接:https://www.acwing.com/solution/content/31030/
来源:AcWing
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

平方矩阵 III

在这里插入图片描述

#include <iostream>using namespace std;int main()
{int n;while(cin >> n,n){for(int i = 0; i < n; i ++){for(int j = 0; j < n; j ++)cout << (1 << i) * (1 << j) << ' ';//两个乘数 后者控制基数 1 ~ 2^(n-1) ,前者控制倍数cout << endl;}cout << endl;}return 0;
}作者:一只草莓
链接:https://www.acwing.com/solution/content/7673/
来源:AcWing
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

蛇形矩阵

在这里插入图片描述
在这里插入图片描述

#include <iostream>
using namespace std;const int N = 110;
int a[N][N];int main()
{int r,c;cin >> r >> c;int left = 0, right = c - 1;int top = 0, bottom = r - 1;int k = 1;while(left <= right || top <= bottom){for(int i = left; i <= right && top <= bottom; i++)//构造最上面一行{a[top][i] = k++;}top++;for(int i = top; i <= bottom && left <= right; i++)//构造最右侧一列{a[i][right] = k++;}right--;for(int i = right; i >= left && top <= bottom; i--)//构造最下面一行{a[bottom][i] = k++;}bottom--;for(int i = bottom; i >= top && left <= right; i--)//构造最左侧一列{a[i][left] = k++;}left++;}for(int i = 0; i < r; i++){for(int j = 0; j < c; j++) cout<< a[i][j] << " ";cout << endl;}return 0;
}作者:Hasity
链接:https://www.acwing.com/solution/content/28991/
来源:AcWing
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

这篇关于C++ 基础速通【数组】Ac-Wing的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1133829

相关文章

C#基础之委托详解(Delegate)

《C#基础之委托详解(Delegate)》:本文主要介绍C#基础之委托(Delegate),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 委托定义2. 委托实例化3. 多播委托(Multicast Delegates)4. 委托的用途事件处理回调函数LINQ

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

C++ 各种map特点对比分析

《C++各种map特点对比分析》文章比较了C++中不同类型的map(如std::map,std::unordered_map,std::multimap,std::unordered_multima... 目录特点比较C++ 示例代码 ​​​​​​代码解释特点比较1. std::map底层实现:基于红黑

C++中函数模板与类模板的简单使用及区别介绍

《C++中函数模板与类模板的简单使用及区别介绍》这篇文章介绍了C++中的模板机制,包括函数模板和类模板的概念、语法和实际应用,函数模板通过类型参数实现泛型操作,而类模板允许创建可处理多种数据类型的类,... 目录一、函数模板定义语法真实示例二、类模板三、关键区别四、注意事项 ‌在C++中,模板是实现泛型编程

利用Python和C++解析gltf文件的示例详解

《利用Python和C++解析gltf文件的示例详解》gltf,全称是GLTransmissionFormat,是一种开放的3D文件格式,Python和C++是两个非常强大的工具,下面我们就来看看如何... 目录什么是gltf文件选择语言的原因安装必要的库解析gltf文件的步骤1. 读取gltf文件2. 提