首页 > 编程语言 >实验1 现代C++编程初体验

实验1 现代C++编程初体验

时间:2024-10-13 11:23:52浏览次数:5  
标签:begin 初体验 end cout int 编程 C++ v0 include

实验任务1:

代码:

 1 #include <iostream>
 2 #include <string>
 3 #include <vector>
 4 #include <algorithm>
 5 
 6 using namespace std;
 7 template<typename T>
 8 void output(const T &c);
 9 void test1();
10 void test2();
11 void test3();
12 
13 int main() {
14     cout << "测试1: \n";
15     test1();
16 
17     cout << "\n测试2: \n";
18     test2();
19 
20     cout << "\n测试3: \n";
21     test3();
22 }
23 
24 template <typename T>
25 void output(const T &c) {
26     for(auto &i: c)
27         cout << i << " ";
28     cout << endl;
29 }
30 
31 void test1() {
32     string s0{"0123456789"};
33     cout << "s0 = " << s0 << endl;
34 
35     string s1{s0};
36     reverse(s1.begin(), s1.end());
37     cout << "s1 = " << s1 << endl;
38 
39     string s2{s0};
40     reverse_copy(s0.begin(), s0.end(), s2.begin());
41     cout << "s2 = " << s2 << endl;
42 }
43 
44 void test2() {
45     vector<int> v0{2, 0, 4, 9};
46     cout << "v0: ";
47     output(v0);
48 
49     vector<int> v1{v0};
50     reverse(v1.begin(), v1.end());
51     cout << "v1: ";
52     output(v1);
53 
54     vector<int> v2{v0};
55     reverse_copy(v0.begin(), v0.end(), v2.begin());
56     cout << "v2: ";
57     output(v2);
58 }
59 void test3() {
60     vector<int> v0{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
61     cout << "v0: ";
62     output(v0);
63 
64     vector<int> v1{v0};
65     rotate(v1.begin(), v1.begin()+1, v1.end());
66     cout << "v1: ";
67     output(v1);
68 
69     vector<int> v2{v0};
70     rotate(v2.begin(), v2.begin()+2, v2.end());
71     cout << "v2: ";
72     output(v2);
73 
74     vector<int> v3{v0};
75     rotate(v3.begin(), v3.end()-1, v3.end());
76     cout << "v3: ";
77     output(v3);
78 
79     vector<int> v4{v0};
80     rotate(v4.begin(), v4.end()-2, v4.end());
81     cout << "v4: ";
82     output(v4);
83 }
任务1

 运行结果:

 

实验任务2:

代码:

 1 #include <iostream>
 2 #include <vector>
 3 #include <string>
 4 #include <algorithm>
 5 #include <numeric>
 6 #include <iomanip>
 7 
 8 using namespace std;
 9 template<typename T>
10 void output(const T &c);
11 
12 int rand_int_100();
13 void test1();
14 void test2();
15 
16 int main() {
17     cout << "测试1: \n";
18     test1();
19 
20     cout << "\n测试2: \n";
21     test2();
22 }
23 
24 
25 template <typename T>
26 void output(const T &c) {
27     for(auto &i: c)
28         cout << i << " ";
29     cout << endl;
30 }
31 int rand_int_100() {
32     return rand() % 101;
33 }
34 
35 void test1() {
36     vector<int> v0(10);
37     generate(v0.begin(), v0.end(), rand_int_100);
38     cout << "v0: ";
39     output(v0);
40 
41     vector<int> v1{v0};
42     sort(v1.begin(), v1.end());
43     cout << "v1: ";
44     output(v1);
45 
46     vector<int> v2{v0};
47     sort(v2.begin()+1, v2.end()-1);
48     cout << "v2: ";
49     output(v2);
50 }
51 
52 void test2() {
53     vector<int> v0(10);  
54     generate(v0.begin(), v0.end(), rand_int_100); 
55     cout << "v0: ";
56     output(v0);
57 
58     auto iter1 = min_element(v0.begin(), v0.end());
59     cout << "最小值: " << *iter1 << endl;
60 
61     auto iter2 = max_element(v0.begin(), v0.end());
62     cout << "最大值: " << *iter2 << endl;
63 
64     auto ans = minmax_element(v0.begin(), v0.end());
65     cout << "最小值: " << *(ans.first) << endl;
66     cout << "最大值: " << *(ans.second) << endl;
67     double avg1 = accumulate(v0.begin(), v0.end(), 0)/v0.size();
68     cout << "均值: " << fixed << setprecision(2) << avg1 << endl;
69 
70     cout << endl;
71 
72     vector<int> v1{v0};
73     cout << "v0: ";
74     output(v0);
75     sort(v1.begin(), v1.end());
76     double avg2 = accumulate(v1.begin()+1, v1.end()-1, 0)/(v1.size()-2);
77     cout << "去掉最大值、最小值之后,均值: " << avg2 << endl;
78 }
任务2

运行结果:

 

实验任务3:

代码:

 1 #include <iostream>
 2 #include <string>
 3 #include <algorithm>
 4 
 5 bool is_palindrome(std::string s);
 6 
 7 int main() {
 8     using namespace std;
 9     string s;
10     while (cin >> s) // 多组输入,直到按下Ctrl+Z后结束测试
11         cout << boolalpha << is_palindrome(s) << endl;
12 }
13 
14 // 函数is_palindrome定义
15 bool is_palindrome(std::string s) {
16     // 判断字符串是否和反转后一致(区分大小写)
17     return s == std::string(s.rbegin(), s.rend());
18 }
任务3

运行结果:

 

实验任务4:

代码:

 1 #include <iostream>
 2 #include <string>
 3 #include <algorithm>
 4 
 5 std::string dec2n(int x, int n = 2);
 6 
 7 int main() {
 8     using namespace std;
 9     int x;
10     while (cin >> x) {
11         cout << "十进制: " << x << endl;
12         cout << "二进制: " << dec2n(x) << endl;
13         cout << "八进制: " << dec2n(x, 8) << endl;
14         cout << "十六进制: " << dec2n(x, 16) << endl << endl;
15     }
16 }
17 
18 std::string dec2n(int x, int n) {
19     if (x == 0) return "0";
20     std::string result;
21     const char digits[] = "0123456789ABCDEF";
22     while (x > 0) {
23         result += digits[x % n];
24         x /= n;
25     }
26     std::reverse(result.begin(), result.end());
27     return result;
28 }
任务4

运行结果:

 

实验任务5:

代码:

 1 #include<iostream>
 2 using namespace std;
 3  int main(){
 4       cout<<"   ";
 5       for(char c='a';c<='z';++c){
 6           cout<<c<<" ";
 7       }
 8       cout<<endl;
 9       for(int i=0;i<26;i++){
10           cout<<(i+1<10 ? " ":"")<<i+1<<" ";
11          for(int j=0;j<26;j++){
12              char letter ='A'+(i+j)%26;
13              cout<<letter<<" ";
14          }
15          cout<<endl;
16      }
17   return 0;
18 }
任务5

实验结果:

 

实验任务6:

代码:

 1 #include<iostream>
 2 #include<random>
 3 #include<iomanip>
 4 
 5 using namespace std;
 6 
 7 int main()
 8 {
 9     mt19937 generator;
10     uniform_int_distribution<int> dis1(1, 10);
11     uniform_int_distribution<int> dis2(1, 4);
12     int count = 1, right = 0;
13     while (count <= 10)
14     {
15         int a = dis1(generator), b = dis1(generator), c = dis2(generator),answer;
16         if (c == 1)
17         {
18             cout << a << " " << "+" << " " << b << " = ";
19             cin >> answer;
20             if (answer == a + b)
21                 right++;
22             count++;
23         }
24 
25         else if (c == 2 && a > b)
26         {
27             cout << a << " " << "-" << " " << b << " = ";
28             cin >> answer;
29             if (answer == a - b)
30                 right++;
31             count++;
32         }
33 
34         else if (c == 3)
35         {
36             cout << a << " " << "*" << " " << b << " = ";
37             cin >> answer;
38             if (answer == a * b)
39                 right++;
40             count++;
41         }
42 
43         else if (c == 4 && a % b == 0)
44         {
45             cout << a << " " << "/" << " " << b << " = ";
46             cin >> answer;
47             if (answer == a / b)
48                 right++;
49             count++;
50         }
51     }
52     cout << "正确率:" << fixed<< setprecision(2)<<(right * 10.0) << "%" << endl;
53     return 0;
54 }
任务6

实验结果:

 

实验总结:

1.在完成实验任务时总出现些许小错误,有输出格式的错误,有写代码时打字的错误,导致做实验的速度下降。

2.任务5、6时部分代码不能通过自己已有的知识完成,通过查阅书籍和网络辅助完成。

3.下次尽量把博客写美观~~~///(^v^)\\\~~~

 

标签:begin,初体验,end,cout,int,编程,C++,v0,include
From: https://www.cnblogs.com/xiarihua/p/18453433

相关文章

  • C++ 非STL数据结构学习——1.4 字典树
    1.字典树的定义字典树是一种多叉树结构,每个节点代表一个字符,从根节点到某个节点的路径表示一个字符串。每个节点包含若干指向子节点的指针,通常使用数组、哈希表或其他数据结构来实现。2.字典树的基本操作插入:将一个字符串插入到字典树中。查找:在字典树中查找一个字符串是否......
  • Linux下C++程序瘦身
    目录一.前言二.如何瘦身三.如何读取调试信息文件四.其他一.前言我们知道,C++程序如果带着调试信息的话会比较大,所以一般发布版本都会去掉调试信息,但是我们又希望如果程序崩溃了可以使用core转储文件进行调试,如果不带调试信息就不能方便的进行调试,那要怎么办呢,这篇文章......
  • 高中生学习c/c++指导
    一、c与c++关系参考图示:可见,c与c++的基本部分是相同的,会有一些小区别,不妨一起学。DEV-C++能支持C++和C语言编程二、学习资料网站介绍1、C语言初阶——手把手教零基础/新手入门2、C++教程从入门到实战3、C++从0到1入门编程......
  • Springboot在线学习辅导管理系统--49101(免费领源码)可做计算机毕业设计JAVA、PHP、爬虫
    摘 要信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题。针对在线学习辅导管理系统等问题,对在线学习辅导管理系统进行研究分析,然后开发设计出在线学习辅......
  • Springboot一个小说阅读APP的设计与实现--48151(免费领源码)可做计算机毕业设计JAVA、PH
    摘 要大数据时代下,数据呈爆炸式地增长。为了迎合信息化时代的潮流和信息化安全的要求,利用互联网服务于其他行业,促进生产,已经是成为一种势不可挡的趋势。在小说在线阅读的需求下,开发一款小说阅读APP,将复杂的系统进行拆分,能够实现对需求的变化快速响应、系统稳定性的保障,能保......
  • 基于SaaS的小区物业管理系统设计与实现--47357(免费领源码)可做计算机毕业设计JAVA、PHP
    摘 要本论文主要论述了如何使用SpringBoot开发一个基于SaaS的小区物业管理系统小程序,本系统将严格按照软件开发流程进行各个阶段的工作,面向对象编程思想进行项目开发。在引言中,作者将论述小区物业管理系统小程序的当前背景以及系统开发的目的,后续章节将严格按照软件开发流程......
  • 每日OJ题_牛客_比那名居的桃子_滑动窗口/前缀和_C++_Java
    目录牛客_比那名居的桃子_滑动窗口/前缀和题目解析C++代码Java代码牛客_比那名居的桃子_滑动窗口/前缀和比那名居的桃子(nowcoder.com)描述:        小红有一天看到了一只桃子,由于桃子看上去就很好吃,小红很想把它吃掉。已知吃下桃子后,每天可以获得ai​的......
  • 从0开始的vscode安装及环境配置教程(C/C++)Windows系统
    1.vscode简介VSCode是微软出的一款轻量级编辑器,它本身只是一款文本编辑器而已,并不是一个集成开发环境(IDE),几乎所有功能都是以插件扩展的形式所存在的。因此,我们想用它编程,不只是把vscode下载下来就行,还需要安装对应编程语言的扩展以及相应的编译器。2.安装vscode进入vscode......
  • C++中比较方便的几个有关字符串的函数
    以下是一些个人总结的C++中对新手来说比较方便使用的几个有关字符串的函数。注意,说的是字符串而不是字符数组。如果有其他,欢迎在评论区留言。1.getline(),这个函数可以输入一行字符串,通常情况下,这个函数的使用通常如下://getline(cin,字符串名);     注意:getline()的......
  • 生产者消费者c++ 讲解和代码示例
    生产者-消费者问题的C++讲解和代码示例一、问题描述生产者-消费者问题是经典的多线程同步问题,涉及两个类型的线程:生产者线程:负责生成数据并放入共享缓冲区。消费者线程:负责从共享缓冲区取出数据进行处理。关键挑战在于:同步:确保生产者和消费者在访问共享缓冲区时不发生......