实验一 现代C++ 基础编程

news/2024/10/14 1:05:58

task1

代码:

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>using namespace std;// 声明
// 模板函数声明
template<typename T>
void output(const T &c);// 普通函数声明
void test1();
void test2();
void test3();int main() {cout << "测试1: \n";test1();cout << "\n测试2: \n";test2();cout << "\n测试3: \n";test3();
}// 函数实现
// 输出容器对象c中的元素
template <typename T>
void output(const T &c) {for(auto &i: c)cout << i << " ";cout << endl;
}// 测试1
// 组合使用算法库、迭代器、string反转字符串
void test1() {string s0{"0123456789"};cout << "s0 = " << s0 << endl;string s1{s0};reverse(s1.begin(), s1.end());  // 反转指定迭代器区间的元素cout << "s1 = " << s1 << endl;string s2{s0};reverse_copy(s0.begin(), s0.end(), s2.begin()); // 将指定迭代区间的元素拷贝到指定迭代器开始的目标区间,并且在复制过程中反转次序cout << "s2 = " << s2 << endl;
}// 测试2
// 组合使用算法库、迭代器、vector反转动态数组对象vector内数据
void test2() {vector<int> v0{2, 0, 4, 9};cout << "v0: ";output(v0);vector<int> v1{v0};reverse(v1.begin(), v1.end());cout << "v1: ";output(v1);vector<int> v2{v0};reverse_copy(v0.begin(), v0.end(), v2.begin());cout << "v2: ";output(v2);
}// 测试3
// 组合使用算法库、迭代器、vector实现元素旋转移位
void test3() {vector<int> v0{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};cout << "v0: ";output(v0);vector<int> v1{v0};rotate(v1.begin(), v1.begin()+1, v1.end());  // 旋转指定迭代器区间[v1.begin(), v1.end())之间的数据项,旋转后从迭代器v1.begin()+1位置的数据项开始cout << "v1: ";output(v1);vector<int> v2{v0};rotate(v2.begin(), v2.begin()+2, v2.end());cout << "v2: ";output(v2);vector<int> v3{v0};rotate(v3.begin(), v3.end()-1, v3.end());cout << "v3: ";output(v3);vector<int> v4{v0};rotate(v4.begin(), v4.end()-2, v4.end());cout << "v4: ";output(v4);
}
View Code

运行截图:

task2

代码:

#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <numeric>
#include <iomanip>using namespace std;// 函数声明
// 模板函数声明
template<typename T>
void output(const T &c);// 普通函数声明
int rand_int_100();
void test1();
void test2();int main() {cout << "测试1: \n";test1();cout << "\n测试2: \n";test2();
}// 函数实现
// 输出容器对象c中的元素
template <typename T>
void output(const T &c) {for(auto &i: c)cout << i << " ";cout << endl;
}// 返回[0, 100]区间内的一个随机整数
int rand_int_100() {return rand() % 101;
}// 测试1
// 对容器类对象指定迭代器区间进行赋值、排序
void test1() {vector<int> v0(10);  // 创建一个动态数组对象v0, 对象大小为10generate(v0.begin(), v0.end(), rand_int_100); // 产生[0, 100]之间的随机整数赋值给指定迭代器区间[v0.begin(), v0.end())内的每个数据项cout << "v0: ";output(v0);vector<int> v1{v0};sort(v1.begin(), v1.end()); // 对指定迭代器区间[v1.begin(), v1.end())内数据项进行升序排序cout << "v1: ";output(v1);vector<int> v2{v0};sort(v2.begin()+1, v2.end()-1); // 对指定迭代器区间[v1.begin()+1, v1.end()-1)内数据项进行升序排序cout << "v2: ";output(v2);
}// 测试2
// 对容器类对象指定迭代器区间进行赋值、计算最大值/最小值/均值
void test2() {vector<int> v0(10);  generate(v0.begin(), v0.end(), rand_int_100); cout << "v0: ";output(v0);auto iter1 = min_element(v0.begin(), v0.end());cout << "最小值: " << *iter1 << endl;auto iter2 = max_element(v0.begin(), v0.end());cout << "最大值: " << *iter2 << endl;auto ans = minmax_element(v0.begin(), v0.end());cout << "最小值: " << *(ans.first) << endl;cout << "最大值: " << *(ans.second) << endl;double avg1 = accumulate(v0.begin(), v0.end(), 0)/v0.size();cout << "均值: " << fixed << setprecision(2) << avg1 << endl;cout << endl;vector<int> v1{v0};cout << "v0: ";output(v0);sort(v1.begin(), v1.end());double avg2 = accumulate(v1.begin()+1, v1.end()-1, 0)/(v1.size()-2);cout << "去掉最大值、最小值之后,均值: " << avg2 << endl;
}
View Code

运行截图:

 task3

代码:

#include <iostream>
#include <string>
#include <algorithm>bool is_palindrome(std::string s);int main() {using namespace std;string s;while(cin >> s)  // 多组输入,直到按下Ctrl+Z后结束测试cout << boolalpha << is_palindrome(s) << endl;
}bool is_palidrome(std::string s){using namespace std;string s1{s};reverse(s1.begin(),s1.end());if(s1==s)return true;elsereturn false;
}
View Code

运行截图:

task4

代码:

#include <iostream>
#include <cstring>
#include <algorithm>std::string dec2n(int x, int n = 2);int main() {using namespace std;int x;while(cin >> x) {cout << "十进制: " << x << endl;cout << "二进制: " << dec2n(x) << endl;cout << "八进制: " << dec2n(x, 8) << endl;cout << "十六进制: " << dec2n(x, 16) << endl << endl;}
}std::string dec2n(int x,int n){using namespace std;if(x==0)return "0";string str;string i="0123456789ABCDEF";while(x>0){int j=x%n;x=x/n;str=str+i[j];}reverse(str.begin(),str.end());return str;
}
View Code

运行截图:

task5

代码:

#include<iostream>
#include<string>
#include<vector>
#include<algorithm>
#include<iomanip>
using namespace std;int main(){cout<<"    ";for(int i=0;i<26;i++)cout<<(char)(i+97)<<" ";cout<<endl;vector<char> v0{'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'};for(int i=1;i<27;i++){vector<char> v1{v0};rotate(v1.begin(),v1.begin()+i,v1.end());cout<<setw(2)<<i<<" ";for(int j=0;j<26;j++){cout<<" "<<v1[j];}cout<<endl;}
} 
View Code

运行截图:

task6

代码:

#include<iostream>
#include<stdlib.h>
#include<time.h>
#include<iomanip> using namespace std;int main(){int a,b,c,d,t;double score=0;srand(time(NULL));for(int i=0;i<10;i++){a=rand()%10;b=rand()%10;t=rand()%4;if(t==1&&a<b)t=0;if(t==3&&a%b!=0)t=2;switch(t){case 0:cout<<a<<"+"<<b<<"=";c=a+b;break;case 1:cout<<a<<"-"<<b<<"=";c=a-b;break;case 2:cout<<a<<"*"<<b<<"=";c=a*b;break;case 3:cout<<a<<"/"<<b<<"=";c=a/b;break;}cin>>d;if(c==d)score=score+10;}cout<<fixed<<setprecision(2)<<score<<"%"<<endl;
}
View Code

运行截图:

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

VMware中三种网络模式(快速笔记)

0、精髓1、桥接模式架构图(VMnet0)与主机共用一块网卡,分配到与主机同网段下的不同的IP地址2、NAT模式架构图(VMnet8)使用虚拟网卡并与主机连接,但共用主机IP3、主机模式架构图(VMnet1)注:本随笔仅为个人速记笔记,详细还请参考这篇博客https://www.cnblogs.com/linjiaxin/p…

Dockerr安装Oracle以及使用DBeaver连接

拉取镜像 pull container-registry.oracle.com/database/free:latest创建容器说明一下我现在的最新版本是23docker run -d --name oracle23i -h xrilang -p 1521:1521 container-registry.oracle.com/database/free:latest查看日志 docker logs oracle23i设置密码 因为创建容器…

数据结构 - 栈

栈是一种特殊线性数据结构,操作遵循后进先出原则,可解决表达式求值等问题。栈分为顺序栈和链栈,各有特点。文章详细介绍了栈的定义、分类及实现方式,包括顺序栈和链栈的ADT定义及基本操作实现。栈一种常见的特殊线性数据结构,其特殊之处在于其操作顺序,下面会详细介绍,也…

《使用Gin框架构建分布式应用》阅读笔记:p20-p31

《用Gin框架构建分布式应用》学习第2天,p20-p31总结,总计12页。 一、技术总结 1.第一个gin程序 // main.go package mainimport "github.com/gin-gonic/gin"func main() {r := gin.Default()r.GET("/", func(c *gin.Context) {c.JSON(200, gin.H{"m…

hot100 review

56. 合并区间 https://leetcode.cn/problems/merge-intervals/description/?envType=study-plan-v2&envId=top-100-liked 该怎么排序区间 vector<vector>& intervals sort(intervals)即可 238. 除自身以外数组的乘积 https://leetcode.cn/problems/product-of-a…

inline、const、mutable、this、static

inline、const、mutable、this、static 在类定义中实现成员函数 incline成员函数末尾的 const(声明和实现中都要加上 const) 作用:告诉系统,这个成员函数不会修改该对象里任何成员变量的值等等,也就是说,这个成员函数不会修改类 Time的任何状态。===> 也叫做常量成员函…

吴恩达机器学习笔记(2-1到2-7)

吴恩达机器学习笔记(2-1到2-7) https://www.bilibili.com/video/BV164411b7dx?p=5 https://www.bilibili.com/video/BV164411b7dx?p=6 https://www.bilibili.com/video/BV164411b7dx?p=7 https://www.bilibili.com/video/BV164411b7dx?p=8 https://www.bilibili.com/vide…

网络安全问题

Linux:在配置Centos7时,刚开始yum不能使用,原因是它默认使用的是自带的yum源,但是这个yum源很不稳定 解决方法:将其换成国内源yum的配置文件在/etc/yum.repos.d/CentOS-Base.repo当中,我们将其切换成阿里云镜像使用这个语句:curl -o /etc/yum.repos.d/CentOS-Base.repo …