C语言实现学生成绩管理系统

2023-05-16

学生管理系统


主界面:


功能选择界面:


所用的函数


函数名;int Num(void);


函数功能: 得到学生人数


函数代码:

//得到学生人数
int Num(void)
{
	printf("请输入学生的人数\n");
	scanf("%d", &num);

	return num;//返回学生人数
}


运行结果:


函数名: struct Student* Input(struct Student *pArr, int len);


函数功能:输入学生信息


函数代码:

struct Student* Input(struct Student *pArr, int len)/*定义一个输入函数,用于输入学生的信息*/
{
	pArr = (struct Student*)malloc(len*sizeof(struct Student));/*为学生分配内存*/

	int i;

	for (i = 0; i < len; i++)
	{
		printf("请输入第%d个学生的姓名:\n", i + 1);/*输入学生的姓名*/
		scanf("%s", pArr[i].Name);

		printf("请输入第%d个学生的年龄:\n", i + 1);/*输入学生的年龄*/
		scanf("%d", &pArr[i].Age);

		printf("请输入学生的学号:\n");;/*输入学生的学号*/
		scanf("%d", &pArr[i].Num);

		printf("请输入第%d个学生的语文成绩:\n", i + 1);/*输入学生的语文成绩*/
		scanf("%f", &pArr[i].Score[0]);

		printf("请输入第%d个学生的数学成绩:\n", i + 1);/*输入学生的数学成绩*/
		scanf("%f", &pArr[i].Score[1]);

		printf("请输入第%d个学生的英语成绩:\n", i + 1);/*输入学生的英语成绩*/
		scanf("%f", &pArr[i].Score[2]);

		//计算总分
		pArr[i].Total = pArr[i].Score[0] + pArr[i].Score[1] + pArr[i].Score[2];

		//计算平均分
		pArr[i].Ave = pArr[i].Total /  3.0f;

	}

	return pArr;   /*返回学生的信息*/
}

运行结果:



函数名: void Output(struct Student *pArr, int len);


函数功能:输出学生信息


函数代码:

/*定义一个输出函数,用于输出学生的信息*/
void Output(struct Student *pArr, int len)
{
	printf("姓名\t年龄\t学号\t语文\t数学\t英语\t总分\t平均分\n");

	for (int i = 0; i < len; i++)
	{
		printf("%s\t%d\t%d\t%g\t%g\t%g\t%g\t%g\n", pArr[i].Name, pArr[i].Age, pArr[i].Num, pArr[i].Score[0], pArr[i].Score[1], pArr[i].Score[2], pArr[i].Total, pArr[i].Ave);
	}
}


运行结果:


函数名:void Delete(struct Student *pArr, int len)
函数功能:删除学生信息
函数代码:
/*定义一个删除函数用于删除学生信息*/
void Delete(struct Student *pArr, int len)
{
	int i, num;
	char str[10];

	printf("请输入你要删除数据的姓名:\n");
	scanf("%s", str);//得到删除学生的姓名

	for (i = 0; i < len; i++)//查找删除的学生的编号
	{
		if (0 == strcmp(pArr[i].Name, str))
		{
			num = i;
		}
	}

	for (i = num; i < len; i++)//删除学生
	{
		pArr[i - 1] = pArr[i];
	}

	Output(pArr, len - 1);//输出删除后的结果
}



执行结果:
函数名:void Search(struct Student *pArr, int len )
函数功能:查找学生信息


函数代码:

/*定义一个查找函数,用于查找结构体*/
void Search(struct Student *pArr, int len)
{
	int i;
	char Name[10];

	printf("请输入一个学生的姓名\n");
	scanf("%s", Name);//得到学生的姓名

	for (i = 0; i < len; i++)//查找学生编号
	{
		if (0 == strcmp(pArr[i].Name, Name))
		{
			num = i;
		}
	}

	Output(&pArr[num],1);//输出找到的学生的信息
}


执行结果:



函数名:void Change(struct Student *pArr, int len)


函数功能:修改学生信息


函数代码:

/*定义一个函数,用于修改结构体*/
void Change(struct Student *pArr, int len)
{
	char Name[10];

	printf("请输入你需要修改的学生的姓名:\n");
	scanf("%s", Name);

	int i, num;

	for (i = 0; i < len; i++)
	{
		if (0 == strcmp(pArr[i].Name, Name))//查找学生编号
		{
			num = i;
		}
	}

	printf("请输入学生的姓名:\n");/*输入学生的姓名*/
	scanf("%s", pArr[num].Name);

	printf("请输入学生的年龄:\n");/*输入学生的年龄*/
	scanf("%d", &pArr[num].Age);

	printf("请输入学生的学号:\n");/*输入学生的学号*/
	scanf("%d", &pArr[num].Num);

	printf("请输入学生的语文成绩:\n");/*输入学生的语文成绩*/
	scanf("%f", &pArr[num].Score[0]);

	printf("请输入学生的数学成绩:\n");/*输入学生的数学成绩*/
	scanf("%f", &pArr[num].Score[1]);

	printf("请输入学生的英语成绩:\n");/*输入学生的英语成绩*/
	scanf("%f", &pArr[num].Score[2]);

	//计算总分
	pArr[num].Total = pArr[num].Score[0] + pArr[num].Score[1] + pArr[num].Score[2];

	//计算平均分
	pArr[num].Ave = pArr[num].Total / 3.0f;

	Output(pArr, len);//输出学生信息
}


执行结果:


函数名:void Add(struct Student *pArr, int len)


函数功能:添加学生信息


函数代码:

//定义一个函数,用于添加学生信息
void Add(struct Student *pArr, int len)
{
	int num,i;

	printf("请输入添加的学生的人数:\n");
	scanf("%d", &num);

	struct Student *p = NULL;

	//动态分配num个内存空间
	p = (struct Student*)malloc(sizeof(struct Student)*num);

	for (i = 0; i < num; i++)
	{
		printf("请输入第%d个学生的姓名:\n", i + 1);/*输入学生的姓名*/
		scanf("%s", p[i].Name);

		printf("请输入第%d个学生的年龄:\n", i + 1);/*输入学生的年龄*/
		scanf("%d", &p[i].Age);

		printf("请输入第%d个学生的学号:\n", i + 1);/*输入学生的学号*/
		scanf("%d", &p[i].Num);

		printf("请输入第%d个学生的语文成绩:\n", i + 1);/*输入学生的语文成绩*/
		scanf("%f",&p[i].Score[0]);

		printf("请输入第%d个学生的数学成绩:\n", i + 1);/*输入学生的数学成绩*/
		scanf("%f", &p[i].Score[1]);

		printf("请输入第%d个学生的英语成绩:\n", i + 1);/*输入学生的英语成绩*/
		scanf("%f", &p[i].Score[2]);

		//计算总分
		p[i].Total = p[i].Score[0] + p[i].Score[1] + p[i].Score[2];

		//计算平均分
		p[i].Ave = p[i].Total / 3.0f;
	}

	Output(pArr, len);//输出学生信息
	Output(p, num);//输出学生信息
}


执行结果:



函数名:void ScoreChinese(struct Student *pArr, int len)


函数功能:对语文成绩排序


函数代码:

/*定义一个排序函数,用于对语文成绩排序*/
void ScoreChinese(struct Student *pArr, int len)
{
	struct Student temp;//中间变量

	for (int i = 0; i < len - 1; i++)//冒泡排序
	{
		for (int j = 0; j < len-i; j++)
		{
			if (pArr[j].Score[0] < pArr[j + 1].Score[0])//对语文成绩从大到小排序
			{
				temp = pArr[j];
				pArr[j] = pArr[j + 1];
				pArr[j + 1] = temp;
			}
		}
	}

	Output(pArr, len);//输出排序后的结果
}

执行结果:

排序前


排序后



函数名:void ScoreMath(struct Student *pArr, int len)


函数功能:对学生的数学成绩排序


函数代码:

/*定义一个排序函数,用于对数学成绩排序*/
void ScoreMath(struct Student *pArr, int len)
{
	struct Student temp;//中间变量

	for (int i = 0; i < len - 1; i++)//冒泡排序
	{
		for (int j = 0; j < len - i; j++)
		{
			if (pArr[j].Score[1] < pArr[j + 1].Score[1])//对数学成绩从大到小排序
			{
				temp = pArr[j];
				pArr[j] = pArr[j + 1];
				pArr[j + 1] = temp;
			}
		}
	}

	Output(pArr, len);//输出排序后的结果
}


执行结果:

排序前:

排序后


函数名:void ScoreEnglish(struct Student *pArr, int len)


函数功能:对学生的英语成绩排序


函数代码:

/*定义一个排序函数,用于对英语成绩排序*/
void ScoreEnglish(struct Student *pArr, int len)
{
	struct Student temp;//中间变量
	int max;//最大值的下标

	for (int i = 0; i < len-1; i++)
	{
		max = i;//假定英语成绩的最大值的下标是i

		for (int j = i + 1; j < len; j++)
		{
			if (pArr[j].Score[2] > pArr[max].Score[2])//查找英语成绩最大值的下标
			{
				max = j;
			}
		}

		if (max != i)//排序
		{
			temp = pArr[max];
			pArr[max] = pArr[i];
			pArr[i] = temp;
		}
	}

	Output(pArr, len);//输出排序后的结果
}

执行结果:

排序前


排序后



函数名:void ScoreTotal(struct Student *pArr, int len)


函数功能:对学生的总成绩排序


函数代码:

/*定义一个排序函数,用于对总成绩排序*/
void ScoreTotal(struct Student *pArr, int len)
{
	struct Student temp;//中间变量
	int max;//最大值的下标

	for (int i = 0; i < len - 1; i++)
	{
		max = i;//假定总成绩的最大值的下标是i

		for (int j = i + 1; j < len; j++)
		{
			if (pArr[j].Total  > pArr[max].Total)//查找总成绩最大值的下标
			{
				max = j;
			}
		}

		if (max != i)//排序
		{
			temp = pArr[max];
			pArr[max] = pArr[i];
			pArr[i] = temp;
		}
	}

	Output(pArr, len);//输出排序后的结果
}


执行结果

排序前


排序后



全部代码:
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
#include <string.h>

#pragma warning(disable:4996)

struct Student/*定义一个结构体*/
{
	char Name[25];/*姓名*/
	int Age;     /*年龄*/
	int Num;    /*学号*/
	float Score[3];/*三科成绩*/
	float Total;/*总分*/
	float Ave;/*平均分*/
};

int num;//学生人数

//得到学生人数
int Num(void);

/*定义一个输入函数,用于输入学生的信息*/
struct Student* Input(struct Student *pArr, int len);

/*定义一个输出函数,用于输出学生的信息*/
void Output(struct Student *pArr, int len);

/*定义一个删除函数用于删除学生信息*/
void Delete(struct Student *pArr, int len);

/*定义一个查找函数,用于查找结构体*/
void Search(struct Student *pArr, int len);

/*定义一个函数,用于修改结构体*/
void Change(struct Student *pArr, int len);

//定义一个函数,用于添加学生信息
void Add(struct Student *pArr, int len);

/*定义一个排序函数,用于对语文成绩排序*/
void ScoreChinese(struct Student *pArr, int len);

/*定义一个排序函数,用于对数学成绩排序*/
void ScoreMath(struct Student *pArr, int len);

/*定义一个排序函数,用于对英语成绩排序*/
void ScoreEnglish(struct Student *pArr, int len);

/*定义一个排序函数,用于对总成绩排序*/
void ScoreTotal(struct Student *pArr, int len);

int main()
{
	int num, Item;
	struct Student *pArr = NULL;
	struct Student *p = NULL;

	printf("================================================================================\n\n");
	printf("================================================================================\n\n");
	printf("*************************欢迎使用学生成绩管理系统*******************************\n\n");
	printf("-----------------------------------------------------------------制作人:梅沙小子\n\n");
	printf("********************************************************************************\n\n");
	printf("================================================================================\n\n");


	printf("请按任意将进入学生管理系统:\n");
	getchar();
	system("cls");

	printf("================================================================================\n\n");
	printf("------------------------ 请选择要操作的命令:-----------------------------------\n\n");
	printf("-------------------------- 1 输入学生信息---------------------------------------\n\n");
	printf("-------------------------- 2 输出学生信息---------------------------------------\n\n");
	printf("-------------------------- 3 删除学生信息---------------------------------------\n\n");
	printf("-------------------------- 4 查找学生信息---------------------------------------\n\n");
	printf("-------------------------- 5 修改学生信息---------------------------------------\n\n");
	printf("-------------------------- 6 增加学生信息---------------------------------------\n\n");
	printf("-------------------------- 7 将学生的语文成绩按从大到小排-----------------------\n\n");
	printf("-------------------------- 8 将学生的数学成绩按从大到小排-----------------------\n\n");
	printf("-------------------------- 9 将学生的英语成绩按从大到小排-----------------------\n\n");
    printf("-------------------------- 10 将学生的总成绩按从大到小排------------------------\n\n");
	printf("================================================================================\n\n");

	while (1)
	{
		printf("\n请选择操作命令;\n");
		scanf("%d", &Item);

		switch (Item)
		{
		     case 1://输入学生信息
			{
				system("cls");
				num = Num();
				p = Input(pArr, num);
			}
			break;

		    case 2://输出学生信息
			{
				system("cls");
				Output(p, num);
			}
			break;

		     case 3://删除学生信息
			{
				system("cls");
				Delete(p, num);
			}
			break;

		     case 4://查找学生信息
			{
				system("cls");
				Search(p, num);
			}
			break;

		     case 5://修改学生信息
			{
				system("cls");
				Change(p, num);
			}
			break;

		     case 6://添加学生信息
			{
				system("cls");
				Add(p, num);
			}
			break;

		    case 7://将学生的语文成绩按从大到小排序
			{
				system("cls");
				ScoreChinese(p, num);
			}
			break;

			case 8://将学生的数学成绩按从大到小排序
				{
					system("cls");
					ScoreMath(p, num);
				}
				break;

			case 9://将学生的英语成绩按从大到小排序
				{
					system("cls");
					ScoreEnglish(p, num);
				}
				break;

			case 10://将学生的总成绩按从大到小排序
				{
					system("cls");
					ScoreTotal(p, num);
				}
				break;
		}
	}
	return 0;
}

//得到学生人数
int Num(void)
{
	printf("请输入学生的人数\n");
	scanf("%d", &num);

	return num;//返回学生人数
}

struct Student* Input(struct Student *pArr, int len)/*定义一个输入函数,用于输入学生的信息*/
{
	pArr = (struct Student*)malloc(len*sizeof(struct Student));/*为学生分配内存*/

	int i;

	for (i = 0; i <len; i++)
	{
		printf("请输入第%d个学生的姓名:\n", i+1);/*输入学生的姓名*/
		scanf("%s", pArr[i].Name);

		printf("请输入第%d个学生的年龄:\n", i+1);/*输入学生的年龄*/
		scanf("%d", &pArr[i].Age);

		printf("请输入第%d个学生的学号:\n",i+1);/*输入学生的学号*/
		scanf("%d", &pArr[i].Num);

		printf("请输入第%d个学生的语文成绩:\n", i+1);/*输入学生的语文成绩*/
		scanf("%f", &pArr[i].Score[0]);

		printf("请输入第%d个学生的数学成绩:\n", i+1);/*输入学生的数学成绩*/
		scanf("%f", &pArr[i].Score[1]);

		printf("请输入第%d个学生的英语成绩:\n", i+1);/*输入学生的英语成绩*/
		scanf("%f", &pArr[i].Score[2]);

		//计算总分
		pArr[i].Total = pArr[i].Score[0] + pArr[i].Score[1] + pArr[i].Score[2];

		//计算平均分
		pArr[i].Ave = pArr[i].Total /  3.0f;

	}

	return pArr;   /*返回学生的信息*/
}


/*定义一个输出函数,用于输出学生的信息*/
void Output(struct Student *pArr, int len)
{
	printf("姓名\t年龄\t学号\t语文\t数学\t英语\t总分\t平均分\n");

	for (int i = 0; i < len; i++)
	{
		printf("%s\t%d\t%d\t%g\t%g\t%g\t%g\t%g\n", pArr[i].Name, pArr[i].Age, pArr[i].Num, pArr[i].Score[0], pArr[i].Score[1], pArr[i].Score[2], pArr[i].Total, pArr[i].Ave);
	}
}

/*定义一个删除函数用于删除学生信息*/
void Delete(struct Student *pArr, int len)
{
	int i, num;
	char Name[10];

	printf("请输入你要删除数据的姓名:\n");
	scanf("%s", Name);//得到删除学生的姓名

	for (i = 0; i < len; i++)//查找删除的学生的编号
	{
		if (0 == strcmp(pArr[i].Name, Name))
		{
			num = i;
		}
	}

	for (i = num; i < len; i++)//删除学生
	{
		pArr[i - 1] = pArr[i];
	}

	Output(pArr, len - 1);//输出删除后的结果
}

/*定义一个查找函数,用于查找结构体*/
void Search(struct Student *pArr, int len)
{
	int i;
	char Name[10];

	printf("请输入你需要查找的学生的姓名\n");
	scanf("%s", Name);//得到学生的姓名

	for (i = 0; i < len; i++)//查找学生编号
	{
		if (0 == strcmp(pArr[i].Name, Name))
		{
			num = i;
		}
	}

	Output(&pArr[num],1);//输出找到的学生的信息
}

/*定义一个函数,用于修改结构体*/
void Change(struct Student *pArr, int len)
{
	char Name[10];

	printf("请输入你需要修改的学生的姓名:\n");
	scanf("%s", Name);

	int i, num;

	for (i = 0; i < len; i++)
	{
		if (0 == strcmp(pArr[i].Name, Name))//查找学生编号
		{
			num = i;
		}
	}

	printf("请输入学生的姓名:\n");/*输入学生的姓名*/
	scanf("%s", pArr[num].Name);

	printf("请输入学生的年龄:\n");/*输入学生的年龄*/
	scanf("%d", &pArr[num].Age);

	printf("请输入学生的学号:\n");/*输入学生的学号*/
	scanf("%d", &pArr[num].Num);

	printf("请输入学生的语文成绩:\n");/*输入学生的语文成绩*/
	scanf("%f", &pArr[num].Score[0]);

	printf("请输入学生的数学成绩:\n");/*输入学生的数学成绩*/
	scanf("%f", &pArr[num].Score[1]);

	printf("请输入学生的英语成绩:\n");/*输入学生的英语成绩*/
	scanf("%f", &pArr[num].Score[2]);

	//计算总分
	pArr[num].Total = pArr[num].Score[0] + pArr[num].Score[1] + pArr[num].Score[2];

	//计算平均分
	pArr[num].Ave = pArr[num].Total / 3.0f;

	Output(pArr, len);//输出学生信息
}

//定义一个函数,用于添加学生信息
void Add(struct Student *pArr, int len)
{
	int num,i;

	printf("请输入添加的学生的人数:\n");
	scanf("%d", &num);

	struct Student *p = NULL;

	//动态分配num个内存空间
	p = (struct Student*)malloc(sizeof(struct Student)*num);

	for (i = 0; i < num; i++)
	{
		printf("请输入第%d个学生的姓名:\n", i + 1);/*输入学生的姓名*/
		scanf("%s", p[i].Name);

		printf("请输入第%d个学生的年龄:\n", i + 1);/*输入学生的年龄*/
		scanf("%d", &p[i].Age);

		printf("请输入第%d个学生的学号:\n", i + 1);/*输入学生的学号*/
		scanf("%d", &p[i].Num);

		printf("请输入第%d个学生的语文成绩:\n", i + 1);/*输入学生的语文成绩*/
		scanf("%f",&p[i].Score[0]);

		printf("请输入第%d个学生的数学成绩:\n", i + 1);/*输入学生的数学成绩*/
		scanf("%f", &p[i].Score[1]);

		printf("请输入第%d个学生的英语成绩:\n", i + 1);/*输入学生的英语成绩*/
		scanf("%f", &p[i].Score[2]);

		//计算总分
		p[i].Total = p[i].Score[0] + p[i].Score[1] + p[i].Score[2];

		//计算平均分
		p[i].Ave = p[i].Total / 3.0f;
	}

	Output(pArr, len);//输出学生信息
	Output(p, num);//输出学生信息
}


/*定义一个排序函数,用于对语文成绩排序*/
void ScoreChinese(struct Student *pArr, int len)
{
	struct Student temp;//中间变量

	for (int i = 0; i < len - 1; i++)//冒泡排序
	{
		for (int j = 0; j < len-i; j++)
		{
			if (pArr[j].Score[0] < pArr[j + 1].Score[0])//对语文成绩从大到小排序
			{
				temp = pArr[j];
				pArr[j] = pArr[j + 1];
				pArr[j + 1] = temp;
			}
		}
	}

	Output(pArr, len);//输出排序后的结果
}

/*定义一个排序函数,用于对数学成绩排序*/
void ScoreMath(struct Student *pArr, int len)
{
	struct Student temp;//中间变量

	for (int i = 0; i < len - 1; i++)//冒泡排序
	{
		for (int j = 0; j < len - i; j++)
		{
			if (pArr[j].Score[1] < pArr[j + 1].Score[1])//对数学成绩从大到小排序
			{
				temp = pArr[j];
				pArr[j] = pArr[j + 1];
				pArr[j + 1] = temp;
			}
		}
	}

	Output(pArr, len);//输出排序后的结果
}


/*定义一个排序函数,用于对英语成绩排序*/
void ScoreEnglish(struct Student *pArr, int len)
{
	struct Student temp;//中间变量
	int max;//最大值的下标

	for (int i = 0; i < len-1; i++)
	{
		max = i;//假定英语成绩的最大值的下标是i

		for (int j = i + 1; j < len; j++)
		{
			if (pArr[j].Score[2] > pArr[max].Score[2])//查找英语成绩最大值的下标
			{
				max = j;
			}
		}

		if (max != i)//排序
		{
			temp = pArr[max];
			pArr[max] = pArr[i];
			pArr[i] = temp;
		}
	}

	Output(pArr, len);//输出排序后的结果
}

/*定义一个排序函数,用于对总成绩排序*/
void ScoreTotal(struct Student *pArr, int len)
{
	struct Student temp;//中间变量
	int max;//最大值的下标

	for (int i = 0; i < len - 1; i++)
	{
		max = i;//假定总成绩的最大值的下标是i

		for (int j = i + 1; j < len; j++)
		{
			if (pArr[j].Total  > pArr[max].Total)//查找总成绩最大值的下标
			{
				max = j;
			}
		}

		if (max != i)//排序
		{
			temp = pArr[max];
			pArr[max] = pArr[i];
			pArr[i] = temp;
		}
	}

	Output(pArr, len);//输出排序后的结果
}


下载学生成绩管理系统


本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

C语言实现学生成绩管理系统 的相关文章

  • Git中stash和stage的差别

    对于初学者来说 xff0c git中stash和stage两个命令的单词有些相似 xff0c 有可能会弄混 其实二者是两个完全不同的概念 1 stash是git中的一个命令 git stash的作用是把工作区 必须是工作区中已经被git追踪
  • 用matlab和RTB做二连杆机械臂动力学建模

    文章目录 写在前面二连杆机械臂RTB建模仿真与验证源代码 写在前面 本文使用的工具为matlab以及Peter Corke的RTB Robotics Toolbox 基于RTB 10 3 1版本 xff0c 我写了RTE Robotics
  • 机械臂协同搬运中的阻抗控制

    文章目录 阻抗模型物体阻抗分布阻抗Matlab和RTB仿真物体阻抗分布阻抗 源代码 阻抗模型 阻抗控制的目的是将原有物体动力学修正为我们期望动力学 假设有一个弹簧 xff0c 通过阻抗控制 xff0c 可以使得它的刚度降低 xff0c 实际
  • MATLAB App Designer生成独立GUI(可执行exe)并添加依赖项

    文章目录 写在前面生成步骤设置编译器编写GUI生成exe 常踩的坑 写在前面 近期 xff0c 由于朋友需求以及科研任务要求 xff0c 我研究了一下MATLAB GUI设计 xff0c 写了两个小程序 一个是读取excel部门名单生成ex
  • 用MATLAB仿真仿射队形变换(affine formation maneuver)

    文章目录 写在前面如何仿真静态编队控制构建stress matrixMATLAB求解LMI问题静态编队控制源代码 如何仿真时变轨迹和队形变换轨迹生成时变leader控制律时变轨迹和队形变换源代码 写在前面 原论文标题 xff1a Affin
  • 多智能体一致性(Consensus)中的矩阵理论(Matrix Theory)

    文章目录 写在前面一致性算法连续时间离散时间 一致性证明连续时间离散时间 矩阵理论特征值和特征向量特征多项式代数重数几何重数 总结 写在前面 最近在看一些分布式优化的文章 xff0c 但是大部分文章都是用的离散时间算法 我之前一直研究的是连
  • 【论文笔记】利用平滑度加速分布式优化——梯度跟踪法(Gradient Tracking)

    文章目录 写在前面问题描述和算法收敛性证明 写在前面 原论文 xff1a Harnessing Smoothness to Accelerate Distributed Optimization 本文是Qu 20181的笔记 xff0c 主
  • 迭代器是什么,C++ STL迭代器(iterator)用法详解

    无论是序列容器还是关联容器 xff0c 最常做的操作无疑是遍历容器中存储的元素 xff0c 而实现此操作 xff0c 多数情况会选用 迭代器 xff08 iterator xff09 来实现 那么 xff0c 迭代器到底是什么呢 xff1f
  • C++ priority_queue 用法详解

    不出所料 xff0c priority queue 容器适配器定义了一个元素有序排列的队列 默认队列头部的元素优先级最高 因为它是一个队列 xff0c 所以只能访问第一个元素 xff0c 这也意味着优先级最高的元素总是第一个被处理 但是如何
  • 数据库|SQLite编程实例---在线词典

    在线词典项目实例 1 在线词典功能分析 在线词典功能分析框图 2 服务器端和客户端流程图 服务器端流程示意图 客户端流程示意图 3 服务器端和客户端源码 服务器端源码 span class token comment dict server
  • 【力扣刷题】动态规划问题的思考与总结

    文章目录 什么是动态规划解决动态规划问题的步骤基础递推算法子问题求和爬楼梯杨辉三角 子问题最值最大子序和 二维DP数组非最优子结构 买卖股票 xff08 多状态递推 xff09 打家劫舍 xff08 分治算法 xff09 贪心算法背包问题
  • 百度2014移动研发笔试题目

    答案仅供参考 一 简答题 1 简述计算机的存储系统分为哪几个层次 xff0c 为什么这样的分层能够提高程序的执行效率 所谓存储系统的层次结构 xff0c 就是把各种不同存储容量 存取速度和价格的存储器按层次结构组成多层存储器 xff0c 并
  • 横屏layout-land失效的细节问题 以及谈谈不同设置模式的优缺点

    android configChanges 61 34 orientation keyboardHidden screenSize 34 设置之后手机可以识别横屏布局 xff0c 但是不会重建 xff0c 但是pad不识别 xff0c 头疼
  • 数学公式汇总

    高等数学公式篇 平方关系 xff1a sin 2 43 cos 2 61 1 tan 2 43 1 61 sec 2 cot 2 43 1 61 csc 2 积的关系 xff1a sin 61 tan cos cos 61 cot sin
  • KEIL ARM 6.12 compiler 编译__ASM 错误的解决方法

    1 问题 KEIL compiler 设置为 use default compiler version 5 可以正确编译以下汇编和C混合代码 xff0c 更改编译器为V6 12后不识别 ASM关键字 xff0c 并对汇编语法报错 替换为 A
  • 面试题:从给定的N个正数中选取若干个数之和最接近M

    这道题跟捞鱼问题一样 xff0c 都是刚进实验室新生培训那会儿做过的题目 xff0c 不过这个是一师姐当时找工作的面试题 如题 xff0c 并输出该子序列 测试用例 xff1a 2 xff0c 9 xff0c 5 xff0c 7 xff0c
  • 贝叶斯最优分类器

    贝叶斯常常有两个问题 xff1a xff08 1 xff09 给定训练数据 xff0c 最可能的假设是什么 xff1f xff08 2 xff09 给定训练数据 xff0c 对新实例的最可能分类是什么 xff1f 第一个问题用最大后验概率
  • 奇异值分解SVD应用—LSI/LSA

    原文 xff1a http blog csdn net abcjennifer article details 8131087 xff08 有看不懂的地方 xff0c 原文评论有点解答 xff09 潜在语义索引 xff08 Latent S

随机推荐

  • EAGAIN、EWOULDBLOCK、EINTR与非阻塞 长连接

    EAGAIN EWOULDBLOCK EINTR与非阻塞 长连接 EWOULDBLOCK用于非阻塞模式 xff0c 不需要重新读或者写 EINTR指操作被中断唤醒 xff0c 需要重新读 写 在Linux环境下开发经常会碰到很多错误 设置e
  • WebSocket 实战

    本文介绍了 HTML5 WebSocket 的由来 xff0c 运作机制及客户端和服务端的 API 实现 xff0c 重点介绍服务端 xff08 基于 Tomcat7 xff09 及客户端 xff08 基于浏览器原生 HTML5 API x
  • FreeRTOS系列|FreeRTOS简介

    FreeRTOS简介 1 RTOS简介 RTOS全称为 Real Time Operation System xff0c 即实时操作系统 RTOS强调的是实时性 xff0c 又分为硬实时和软实时 硬实时要求在规定的时间内必须完成操作 xff
  • makefile 编写之32 or 64位机器

    一 Makefile 判断 64位机器 ARCH 61 shell uname m BIT32 61 i686 BIT64 61 x86 64 all clean ifeq ARCH BIT64 64 echo x86 64 make Su
  • linux多行注释

    1 多行注释 xff1a 1 首先按esc进入命令行模式下 xff0c 按下Ctrl 43 v xff0c 进入列 xff08 也叫区块 xff09 模式 2 在行首使用上下键选择需要注释的多行 3 按下键盘 xff08 大写 xff09
  • linux多线程信号处理

    在linux下 xff0c 每个进程都有自己的signal mask xff0c 这个信号掩码指定哪个信号被阻塞 xff0c 哪个不会被阻塞 xff0c 通常用调用sigmask来处理 同时每个进程还有自己的signal action xf
  • Mysql的row_format

    问题描述 xff1a You have an error in your SQL syntax check the manual that corresponds to your MySQL server version for the r
  • MetricsSystem

    Metrics xff0c 我们听到的太多了 xff0c 熟悉大数据系统的不可能没听说过metrics xff0c 当我们需要为某个系统某个服务做监控 做统计 xff0c 就需要用到Metrics 举个例子 xff0c 一个图片压缩服务 x
  • Hazelcast集群服务(1)——Hazelcast介绍

    https www cnblogs com hunter 56213 p 6230442 html Hazelcast是什么 分布式 集群服务 网格式内存数据 分布式缓存 弹性可伸缩服务 这些牛逼闪闪的名词拿到哪都是ITer装逼的不二之选
  • 小议同步IO :fsync与fdatasync

    对于提供事务支持的数据库 xff0c 在事务提交时 xff0c 都要确保事务日志 xff08 包含该事务所有的修改操作以及一个提交记录 xff09 完全写到硬盘上 xff0c 才认定事务提交成功并返回给应用层 一个简单的问题 xff1a 在
  • 阿里云 李博

    机器学习基础知识 业务架构 xff1b 算法代替人类思考 xff0c 实现生产力飞跃 xff0c xff1b 大部分开源工具封装了算法 xff1b 无需算法开发以及算法的公式推导 xff1b 如何使用算法解决自身的应用场景 xff1b 业务
  • thinkphp中display调用模板文件详…

    模板变量赋值后就需要调用模板文件来输出相关的变量 xff0c 模板调用通过display方法来实现 我们在操作方法的最后使用 xff1a this gt display 就可以输出模板 xff0c 根据前面的模板定义规则 xff0c 因为系
  • 遥控器与电调相关知识点整理

    一 xff0c 电调的控制方法 PWM 单片机输出1ms 2ms的方波脉冲 xff0c 根据航模标准 xff0c PWM信号线的频率应该是50Hz xff0c 对应的每个周期总时长是20ms xff0c 输出到电调的油门线 xff08 控制
  • FreeRTOS系列|开发环境

    开发环境搭建 1 硬件开发环境 FreeRTOS系列所使用的硬件为STM32F103ZET6开发板 2 软件开发环境 2 1 Keil MDK ARM软件简介及安装 2 1 1 Keil MDK ARM简介 Keil MDK xff0c 也
  • 陀螺仪加速度计MPU6050

    转载自 xff1a http www crazepony com wiki mpu6050 html 陀螺仪 陀螺仪 xff0c 测量角速度 xff0c 具有高动态特性 xff0c 它是一个间接测量角度的器件 它测量的是角度的导数 xff0
  • 机器学习-Anomaly Detection

    Problem Motivation 异常检测 Anomaly detection 是机器学习算法的一个常见应用 这种算法的一个有趣之处在于 xff1a 它虽然主要用于非监督学习问题 xff0c 但从某些角度看 xff0c 它又类似于一些监
  • Quadrotor四旋翼飞行器的飞…

    原文地址 xff1a Quadrotor四旋翼飞行器的飞行原理 xff08 一 xff09 作者 xff1a hxl85 http en wikipedia org wiki Quadrotor 这是wiki上的介绍 xff0c 有兴趣可以
  • 姿态解算知识(三)-陀螺仪加速度计6轴数据融合

    这么久的惯导总算是没白看 xff0c 加上一篇博客的指点 xff0c 这两天把Mahony的九轴数据融合算法看懂了 可惜第二版硬件还没到 xff0c 磁力计用不了 xff0c 没法验证效果 今天先总结下陀螺仪和加速度计的六轴数据融合 版权声
  • (含代码)ESP8266+舵机 制作wifi灯控开关(arduino,点灯科技,小爱同学/天猫精灵实现)

    目录 项目涉及的主代码 前言 一 环境搭建 二 开发步骤 1 注册点灯科技平台 2 在点灯科技平台注册设备 xff0c 获取Secret Key 3 在Arduino IDE中编写代码 xff0c 写入ESP8266 4 编译固件 xff0
  • C语言实现学生成绩管理系统

    学生管理系统 主界面 功能选择界面 所用的函数 函数名 int Num void 函数功能 得到学生人数 函数代码 得到学生人数 int Num void printf 34 请输入学生的人数 n 34 scanf 34 d 34 amp