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

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

时间:2024-10-09 16:33:31浏览次数:8  
标签:begin 初体验 end cout int 编程 C++ v0 include

任务一

#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();
}

template <typename T>
void output(const T &c) {
for(auto &i: c)
cout << i << " ";
cout << endl;
}

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;
}

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);
}

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()); 
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);
}

任务二

#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();
}
template <typename T>
void output(const T &c) {
for(auto &i: c)
cout << i << " ";
cout << endl;
}

int rand_int_100() {
return rand() % 101;
}

void test1() {
vector<int> v0(10);
generate(v0.begin(), v0.end(), rand_int_100); 
cout << "v0: ";
output(v0);
vector<int> v1{v0};
sort(v1.begin(), v1.end());
cout << "v1: ";
output(v1);
vector<int> v2{v0};
sort(v2.begin()+1, v2.end()-1);
cout << "v2: ";
output(v2);
}

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;
}

任务三

#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;
}
// 函数is_palindrom定义
// 待补足
bool is_palindrome(std::string s){
	std::string s1{s};
	reverse(s1.begin(),s1.end());
	if(s1==s){
		return true;
	}
	else{
		return false;
	}
} 

任务四

#include <iostream>
#include <string>
#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;
}
}
// 函数dec2n定义
// 待补足
std::string dec2n(int x,int n){
	std::string s1;
	if(x==0){
		s1.push_back('0');
	}
	else{
		while(x){
			char c;
			int a;
			a=x%n;
			x/=n;
			if(a<10){
				c='0'+a;
				s1.push_back(c);
			}
			else{
				switch(a){
					case 10:c='A';break;
					case 11:c='B';break;
					case 12:c='C';break;
					case 13:c='D';break;
					case 14:c='E';break;
					case 15:c='F';break;
				}
				s1.push_back(c);
			}
			
		}
		reverse(s1.begin(),s1.end());
	}
	return s1;
}

任务五

#include<iostream>
#include<iomanip>
#include<string>

using namespace std;

int main(){
	string s("ABCDEFGHIJKLMNOPQRSTUVWXYZ");
	for(int i=0;i<27;i++){
		for(int j=0;j<26;j++){
			if(j==0){
				if(i==0){
					cout<<setw(2)<<" ";
				}
				else{
					cout<<setw(2)<<i;
				}
			}
			else{
				if(i==0){
					cout<<setw(2)<<char(s[j-1]+32);
				}
				else{
					cout<<setw(2)<<s[(j+i-1)%26];
				}
			}
		}
		cout<<endl;
	}
}

任务六

#include<iostream>
#include<iomanip>
#include<stdlib.h>
#include<time.h>
#include<map>

using namespace std;

int main(){
	int a,b,c,d,res,count=0;
	float e;
	char x;
	map<int,char>mp={{1,'+'},{2,'-'},{3,'*'},{4,'/'}};
	srand(time(NULL));
	
	for(int i=0;i<10;i++){
		
		a=rand()%10+1;
		b=rand()%10+1;
		c=rand()%4+1;
		if(c==2){
			while(a<b){
				a=rand()%10+1;
			}
		}
		else if(c==4){
			while(a%b!=0){
				a=rand()%10+1;
				
			}
		}
		switch(c){
			case 1:res=a+b;break;
			case 2:res=a-b;break;
			case 3:res=a*b;break;
			case 4:res=a/b;break;
		}
		cout<<setw(2)<<a<<setw(2)<<mp[c]<<setw(2)<<b<<setw(2)<<"=";
		cin>>d;
		if(d==res){
			count++;
		}
	}
	e=count*10;
	cout<<fixed<<setprecision(2)<<e<<"%"<<endl;
	
}

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

相关文章

  • C++编译并运行后出现Process finished with exit code 139 (interrupted by signal 11
    问题描述:        代码运行意外终止,报错信息为Processfinishedwithexitcode139(interruptedbysignal11:SIGSEGV)CMakeList文件如下:cmake_minimum_required(VERSION3.26)project(SLAM)set(CMAKE_CXX_STANDARD17)set(CMAKE_CXX_STANDARD_REQUIRED......
  • Java并发编程:深入探索与实战案例
    Java并发编程:深入探索与实战案例在当今的多核处理器时代,并发编程已成为提升应用程序性能、优化资源利用的关键技术之一。Java,作为一门广泛应用的编程语言,凭借其强大的并发处理能力,在众多编程语言中脱颖而出。本文将深入探讨Java并发编程的核心概念、常用工具及实战案例,旨在......
  • 【javascript 编程】Web前端之JavaScript动态添加类名的两种方法、区别、className、c
    通过className来添加或删除类名添加类名获取元素el.className="类名1类名2...";多个类名用空格隔开。移除类名获取元素名el.className="";直接等于一个空字符串即可删除类名。通过classList来添加或删除类名添加一个类名获取元素名el.classList.add("类名");。......
  • 调用sdapi/v1/txt2img接口,报错“Couldn‘t load custom C++ ops”
    后端启动stable_diffusion的api接口nohuppythonlaunch.py --use-cpuall--skip-torch-cuda-test   --api--api-log  --listen--server-name192.168.1.204>/home/third_party_app/llm/stable-diffusion-webui/logs/all.log2>&1 &服务接口http://192.168......
  • (2024最新毕设合集)基于SpringBoot的乡村书屋小程序-31881|可做计算机毕业设计JAVA、PHP
    摘要随着信息技术的快速发展和互联网的广泛普及,数字化服务的需求不断增长,乡村书屋作为传统的文化服务机构也需要适应这一变革。本研究将使用Java开发技术,通过springboot作为框架,结合微信小程序,和MySQL作为数据存储的技术,开发一套功能齐备可移动的乡村书屋小程序,旨在提升乡......
  • 【C++】priority_queue的介绍和模拟实现
    【C++】priority_queue的介绍和模拟实现一.priority_queue的介绍1.priority_queue的基本介绍2.priority_queue的使用介绍二.priority_queue的模拟实现一.priority_queue的介绍1.priority_queue的基本介绍优先队列是一种容器适配器,根据严格的弱排序标准,它的......
  • C++ day04(友元 friend、运算符重载、String字符串)
    目录【1】友元friend1》概念2》友元函数 3》友元类 4》友元成员函数 【2】运算符重载1》概念2》友元函数运算符重载 ​编辑 3》成员函数运算符重载4》赋值运算符与类型转换运算符重载 5》注意事项【3】String字符串类【1】友元friend1》概念定义:......
  • 《 C++ 修炼全景指南:十四 》大数据杀手锏:揭秘 C++ 中 BitSet 与 BloomFilter 的神奇性
    本篇博客深入探讨了C++中的两种重要数据结构——BitSet和BloomFilter。我们首先介绍了它们的基本概念和使用场景,然后详细分析了它们的实现方法,包括高效接口设计和性能优化策略。接着,我们通过对比这两种数据结构的性能,探讨了在不同应用场景中的选择依据。最后,博客还涵盖......
  • 一文通Java 锁:锁机制及锁常见问题的深入解析(Java 并发编程(偏向、轻/重量级、读写、可
    在并发编程中,锁机制是保障线程安全的核心工具。锁的类型、使用场景、以及锁引发的种种问题都是开发者在设计高并发系统时必须应对的挑战。本篇博客将围绕锁的类型、应用场景、以及常见的锁问题展开详细讨论,帮助大家深入理解Java锁机制的优缺点与其适用场景。文章目录......
  • 【C++】二叉搜索树
    文章目录1、二叉搜索树的说明性2、二叉搜索树2.1二叉搜索树的概念2.2二叉搜索树的操作2.2.1插入2.2.2查找2.2.3删除2.3二叉搜索树的实现2.4二叉搜索树的应用二叉搜索树的性能分析1、二叉搜索树的说明性map和set特性需要先铺垫二叉搜索树,而二叉搜索树也是一种树形......