【C/C++学院】0817-递归汉诺塔 双层递归 /CPP结构体 /面向过程与面向对象的编程模式/类的常识共用体实现一个类的特征/QT应用于类以及类的常识

简介: <p></p> <h1>递归汉诺塔 双层递归</h1> <pre name="code" class="java">#include <iostream>void han(int n, char A, char B, char C){ static int num = 1; std::cout << "第" << num <<

递归汉诺塔 双层递归

#include <iostream>

void han(int n, char A, char B, char C)
{
	static int  num = 1;
	std::cout << "第" << num << "次";
	num++;
	if (n<1)
	{
		return;
	} 
	else
	{
		han(n - 1, A, C, B);
		std::cout << A << "->" << C << std::endl;
		han(n - 1, B, A, C);
	}
}

//  f(n)=2*f(n-1)+1 //f(n)=2^n-1
//2^64- 1
void main()
{
	int n;
	std::cin >> n;
	std::cout << "n=" << n << std::endl;
	han(n, 'A', 'B', 'C');
	std::cin.get();
	std::cin.get();
}

CPP结构体 

#include<iostream>

struct lstruct
{
	int num;
};

struct MyStruct
{
	int num;
	double db=10.8;//默认的值
	//MyStruct sx;//拒绝内部定义自己
	MyStruct *pnext;
	MyStruct *phead;
	lstruct  l1;
	void boss()
	{

	}
};

struct MyStructA
{
	int num;
	double db = 10.8;//默认的值
	//MyStruct sx;//拒绝内部定义自己
	MyStruct *pnext;
	MyStruct *phead;
	lstruct  l1;
	void boss()
	{

	}
};

struct 
{
	int num;
	double db ;//默认的值
	MyStruct boss1;
}sx,sy;//匿名结构体不允许初始化

void main()
{
	MyStruct s1;//自动管理
	MyStruct *pnew = new MyStruct;//手动
	s1.l1.num;
	//pnew->l1.num;
	(*pnew).l1.num;
	//类型相同可以整体赋值
	//结构体C++风格初始化方式
	MyStruct s2(s1);
	MyStruct *pnew2(new MyStruct);
	MyStructA sa1;
	//MyStruct s3(sa1);C++强类型,必须类型匹配
}

void main1()
{
	MyStruct  s1;
	std::cout << s1.db << std::endl;
	sx.boss1.num;//结构体嵌套就是...
	std::cin.get();
}

面向过程与面向对象的编程模式

C管理进程

#define  _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include<string.h>
#include<windows.h>

//面向过程的模式
//代码重用主要靠函数
//权限,

void open(const char *path,const int mode)
{
	ShellExecuteA(0, "open", path, 0, 0, mode);
}

void all()
{
	system("tasklist");
}

void closebyname(const char *name)
{
	char cmdstr[100] = { 0 };
	sprintf(cmdstr, "taskkill /f /im %s", name);
	system(cmdstr);
}

void closebypid(const int num)
{
	char cmdstr[100] = { 0 };
	sprintf(cmdstr, "taskkill /pid %d", num);
	system(cmdstr);
}


void main1()
{
	all();
	open("notepad", 1);
	all();
	Sleep(2000);
	int  num;
	scanf("%d", &num);
	closebypid(num);
	//closebyname("notepad.exe");
	system("pause");
}
//复数a+bi
struct fu
{
	int a;
	int b;
};

//a+ bi,
struct fu  add(struct fu  fu1, struct fu  fu2)
{
	struct fu  fu3;
	fu3.a = fu1.a + fu2.a;
	fu3.b = fu1.b + fu2.b;
	return fu3;
}

void   main3()
{
	//数据可以随便被别人,可以随便被修改
	struct fu  fu1 = { 3, 4 };
	struct fu  fu2 = { 13, 4 };
	fu1.a += 3;
	struct fu  fu3 = add(fu1, fu2);
	printf("%d+%di", fu3.a, fu3.b);
	getchar();
}

面向对象管理进程

#define  _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<string>
#include <windows.h>

//C++类的继承实现代码重用, C重用   函数
//类的封装实现权限,封装,数据与代码合为一体。C封装主要是函数
//封装可以锁定代码的权限,锁定的数据的权限,避免被随意修改
//类的多态,一个接口根据实际需求完成很多不同的功能

class cmduse
{
private:
	char cmduser[100];//用户名
	char cmd[100];//存储指令
public:
	void setuser(const char * name)
	{
		strcpy(cmduser, name);
	}
	char * getuser()
	{
		return this->cmduser;//返回用户名
	}
	void open(const char *path, const int mode)
	{
		ShellExecuteA(0, "open", path, 0, 0, mode);
	}
	void all()
	{
		system("tasklist");
	}
	void closebyname(const char *name)
	{
		memset(this->cmd, 0, 100);//清空字符串
		sprintf(this->cmd, "taskkill /f /im %s", name);
		system(this->cmd);
	}
	void closebypid(const int num)
	{
		memset(this->cmd, 0, 100);//清空字符串
		sprintf(this->cmd, "taskkill /pid %d", num);
		system(this->cmd);
	}
};

void main2()
{
	cmduse cmduse1;
	cmduse1.setuser("yincheng");
	std::cout << cmduse1.getuser() << std::endl;
	cmduse1.open("calc",1);
	cmduse1.open("notepad",0);
	Sleep(2000);
	cmduse1.all();
	cmduse1.closebyname("calc");
	int pid;
	std::cin >> pid;
	cmduse1.closebypid(pid);//根据编号关闭

	std::cin.get();
	std::cin.get();
	//closebypid(100);

}

//封装可以实现代码权限,不可以随便调用
class 
{
public:
	void seta(int a)
	{
		//接口
		this->a = a;
	}
	int geta()
	{
		return this->a;
	}
	void setb(int b)
	{
		//接口
		this->b = b;
	}
	int getb()
	{
		return this->b;
	}

protected:

private:
	int a;
	int b;
	char password[100];
}myab;

void main()
{

//	myab.geta = 3;
	myab.seta(10);
	//封装解决的问题
	//类的,代码与数据,一体化
    //代码的封装,限定代码谁可以执行谁不可以执行的权限
	//数据的封装,防止数据被意外修改
}

类的常识共用体实现一个类的特征

#include<iostream>

//union  本质也是一个类,可以内部有函数,
//union,内部数据是共享,不同对象之间是独立的,代码是共享
//union,也具备结构体所有功能
//某些节约内存的类需要用到共用体
union MyUnion
{
	int num;
	double db;
	void go()
	{

	}
};
//内部数据是共享内存,不可以继承
union MyUnionA 
{
	int num;
	double db;
	void go()
	{

	}
};

void main()
{
	std::cout << sizeof(MyUnion) << std::endl;
	MyUnion union1;
//	union1.db = 10;
	union1.num = 20;
	std::cout << union1.num << std::endl;
	union1.db = 10.9;//时时刻刻共用体仅有一个变量存在

	std::cout << union1.num << std::endl;
	std::cin.get();	
}

QT应用于类以及类的常识

空类

#include<iostream>

//空类占一个字节,表明类存在
//空类有int,占4个,
//
class kong
{
public:
	//int num;

	void go(int  num)
	{
		std::cout << "锄禾日当午";
     }
};

void main()
{
	std::cout << sizeof(kong) << std::endl;
//	std::cout << &kong << std::endl;
	kong  kong1;
	//kong1.num = 10;
	std::cout << &kong1 << std::endl;

	std::cin.get();
}

Qtobj

#include "dialog.h"
#include <QApplication>

class bigsmall
{
    Dialog  *p;
public:
    void setp(Dialog  *p)
    {
        this->p=p;
    }
    void set(int x,int y)
    {
        this->p->resize(x,y);//设置大小

    }
    void big()
    {
        for(int i=0;i<600;i++)
        {
             this->p->resize(i,i);
        }
    }
    void small()
    {
        for(int i=600;i>=0;i--)
        {
             this->p->resize(i,i);
        }
    }
};

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

//    Dialog  mydialog1,mydialog2;

   // mydialog1.show();
   // mydialog2.show();

   Dialog  *pd1,*pd2;
   pd1=new Dialog;
   pd2=new Dialog;
  // pd1->show();
  // pd2->show();
   pd1->resize(800,600);

   pd2->resize(600,800);

   (*pd1).show();
   (*pd2).show();

   bigsmall  bigsmall1;
   bigsmall1.setp(pd1);
   bigsmall1.big();
   bigsmall1.small();

   bigsmall  bigsmall2;
   bigsmall2.setp(pd2);
   bigsmall2.big();
   bigsmall2.small();

   //delete pd1;
  // delete pd2;

    return a.exec();
}







目录
相关文章
|
4天前
|
监控 Linux C++
4步实现C++插件化编程,轻松实现功能定制与扩展(2)
本文是《4步实现C++插件化编程》的延伸,重点介绍了新增的插件“热拔插”功能。通过`inotify`接口监控指定路径下的文件变动,结合`epoll`实现非阻塞监听,动态加载或卸载插件。核心设计包括`SprDirWatch`工具类封装`inotify`,以及`PluginManager`管理插件生命周期。验证部分展示了插件加载与卸载的日志及模块状态,确保功能稳定可靠。优化过程中解决了动态链接库句柄泄露问题,强调了采纳用户建议的重要性。
4步实现C++插件化编程,轻松实现功能定制与扩展(2)
|
7天前
|
设计模式 安全 C++
【C++进阶】特殊类设计 && 单例模式
通过对特殊类设计和单例模式的深入探讨,我们可以更好地设计和实现复杂的C++程序。特殊类设计提高了代码的安全性和可维护性,而单例模式则确保类的唯一实例性和全局访问性。理解并掌握这些高级设计技巧,对于提升C++编程水平至关重要。
37 16
|
11天前
|
安全 C++
【c++】继承(继承的定义格式、赋值兼容转换、多继承、派生类默认成员函数规则、继承与友元、继承与静态成员)
本文深入探讨了C++中的继承机制,作为面向对象编程(OOP)的核心特性之一。继承通过允许派生类扩展基类的属性和方法,极大促进了代码复用,增强了代码的可维护性和可扩展性。文章详细介绍了继承的基本概念、定义格式、继承方式(public、protected、private)、赋值兼容转换、作用域问题、默认成员函数规则、继承与友元、静态成员、多继承及菱形继承问题,并对比了继承与组合的优缺点。最后总结指出,虽然继承提高了代码灵活性和复用率,但也带来了耦合度高的问题,建议在“has-a”和“is-a”关系同时存在时优先使用组合。
54 6
|
1月前
|
存储 缓存 C++
C++ 容器全面剖析:掌握 STL 的奥秘,从入门到高效编程
C++ 标准模板库(STL)提供了一组功能强大的容器类,用于存储和操作数据集合。不同的容器具有独特的特性和应用场景,因此选择合适的容器对于程序的性能和代码的可读性至关重要。对于刚接触 C++ 的开发者来说,了解这些容器的基础知识以及它们的特点是迈向高效编程的重要一步。本文将详细介绍 C++ 常用的容器,包括序列容器(`std::vector`、`std::array`、`std::list`、`std::deque`)、关联容器(`std::set`、`std::map`)和无序容器(`std::unordered_set`、`std::unordered_map`),全面解析它们的特点、用法
C++ 容器全面剖析:掌握 STL 的奥秘,从入门到高效编程
|
1月前
|
存储 算法 C++
深入浅出 C++ STL:解锁高效编程的秘密武器
C++ 标准模板库(STL)是现代 C++ 的核心部分之一,为开发者提供了丰富的预定义数据结构和算法,极大地提升了编程效率和代码的可读性。理解和掌握 STL 对于 C++ 开发者来说至关重要。以下是对 STL 的详细介绍,涵盖其基础知识、发展历史、核心组件、重要性和学习方法。
|
1月前
|
编译器 C++ 开发者
【C++篇】深度解析类与对象(下)
在上一篇博客中,我们学习了C++的基础类与对象概念,包括类的定义、对象的使用和构造函数的作用。在这一篇,我们将深入探讨C++类的一些重要特性,如构造函数的高级用法、类型转换、static成员、友元、内部类、匿名对象,以及对象拷贝优化等。这些内容可以帮助你更好地理解和应用面向对象编程的核心理念,提升代码的健壮性、灵活性和可维护性。
|
1月前
|
安全 编译器 C语言
【C++篇】深度解析类与对象(中)
在上一篇博客中,我们学习了C++类与对象的基础内容。这一次,我们将深入探讨C++类的关键特性,包括构造函数、析构函数、拷贝构造函数、赋值运算符重载、以及取地址运算符的重载。这些内容是理解面向对象编程的关键,也帮助我们更好地掌握C++内存管理的细节和编码的高级技巧。
|
1月前
|
存储 程序员 C语言
【C++篇】深度解析类与对象(上)
在C++中,类和对象是面向对象编程的基础组成部分。通过类,程序员可以对现实世界的实体进行模拟和抽象。类的基本概念包括成员变量、成员函数、访问控制等。本篇博客将介绍C++类与对象的基础知识,为后续学习打下良好的基础。
|
1月前
|
编译器 C语言 C++
类和对象的简述(c++篇)
类和对象的简述(c++篇)
|
2月前
|
C++ 芯片
【C++面向对象——类与对象】Computer类(头歌实践教学平台习题)【合集】
声明一个简单的Computer类,含有数据成员芯片(cpu)、内存(ram)、光驱(cdrom)等等,以及两个公有成员函数run、stop。只能在类的内部访问。这是一种数据隐藏的机制,用于保护类的数据不被外部随意修改。根据提示,在右侧编辑器补充代码,平台会对你编写的代码进行测试。成员可以在派生类(继承该类的子类)中访问。成员,在类的外部不能直接访问。可以在类的外部直接访问。为了完成本关任务,你需要掌握。
85 19

热门文章

最新文章

推荐镜像

更多