C++杂记

  1. string 不可以直接scanf() , 必须预分配空间. 也不可以直接printf(),因为非内置,必须:string.c_str().
    strinfg 的 compare()函数可以按字典比较字符串大小 : a.compare(b),a < b return 负数, a = b return 0, a > b return 正数.
    char数组的比较用<string.h>下的strcmp()函数,返回分类同上。
#include <stdio.h>
#include <string>
using namespace std;
int main()
{
	string a;
	a.resize(100); //需要预先分配空间
	scanf("%s", &a[0]);
	
	string b = "ab";
	string c = "a";
	printf("%s compare %s :%d\n",b.c_str(),c.c_str(),b.compare(c));
	return 0;
}
  1. 并查集在统计一些事务如最短路径时,最好在合并时做操作。
  2. 图形类输出可以按行列输出(当操作和输出规律可结合时),也可以存在一个二维数组中再输出(当直接操作不便时)。
  3. 有向图的遍历:
    链式前向星(无向图也可)
    int head[50];
    int k = 0;
    struct E{
    	int v;
      int cost;
      int next;
    }edge[50];
    void add(int u,int v){
    	edge[++k].next = head[u];
    	edge[k].v = v;
    	head[u] = k;
    	
    }
    void travel(int u){
    	for(int i = head[u]; i != -1; i = edge[i].next){
    		int v = edge[i].v;
    		....
    	}
    }
    
  4. gets(s)函数与scanf("%s",s)相似,但不完全相同,使用scanf("%s",s) 函数输入字符串时存在一个问题,就是如果输入了空格会认为字符串结束,空格后的字符将作为下一个输入项处理,但gets()函数将接收输入的整个字符串直到遇到换行为止。
    也就是说:gets()函数读取到\n(我们输入的回车)于是停止读取,但是它不会把\n包含到字符串里面去(同时吸收回车)。然而,和它配合使用的puts函数,却在输出字符串的时候自动换行。

输入为"test\nabcd"。
执行gets后,\n不会留在缓冲区中,即这时调用getchar得到的字符是’a’。
执行scanf后,\n会留在缓冲区,这时调用getchar得到的字符是’\n’。

但是gets()默认缓冲区是无限的,是否足够由程序员来保证,不够安全。现在已换成gets_s(),必须指明缓冲大小,超过大小的将被截掉。

#include <stdio.h>//gets_s()用法
#define CH 20
int main(void)
{
    char ch[CH];
    printf("请输入你的名字:\n");
    gets_s(ch,CH);             //这里不能用gets_s(ch);
    printf("这是你的名字:%s\n", ch);
    return 0;
}
  1. 排名函数一般要求分数不同排名不同,分数相同排名相同但占用一个排位。具体实现:分数与上一个同则排名同,不同则排名=下标+1
  2. 最小生成树的Kruskal算法在输入可能有重边的时候要加入有效边判断:
//注释掉的部分就是判断重边
//如重复输入两个结点间权值
			int ans = 0;
			//int cnt = 0;
			for (int i = 0; i < esize; ++i) {
				int u = edge[i].u;
				int v = edge[i].v;
				int cost = edge[i].cost;
				if (!same(u, v)) {
					//++cnt;
					ans += cost;
					merge(u, v);
				}
				//if (cnt >= n-1)break;
			}
  1. string 类型读取一行:getline(cin,str)
  2. VS能用gets_s,POJ提交不了,还是用gets
  3. 10.qsort的用法:给一个char[ ][ ]类型的数组排序:
char telNum[100000][9];
//自定义比较器
//返回值是int ,参数是const void *
int cmp(const void *a, const void *b) {
	return strcmp((char *)a, (char *)b);
}

//引用的时候,数组名,数组长度,数组元素长度,比较器
qsort(telNum, n, 9, cmp);
  1. 字符串类型的题目中,有时候字符出现频次是一个很好的特征属性。如
    POJ2801 填词
    POJ2820 古代密码

  2. 字符串转为double用atof()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
大学生就业服务平台管理系统按照操作主体分为管理员和用户。管理员的功能包括学生档案管理、字典管理、试卷管理、试卷选题管理、试题表管理、考试记录表管理、答题详情表管理、错题表管理、法律法规管理、法律法规收藏管理、法律法规留言管理、就业分析管理、论坛管理、企业管理、简历管理、老师管理、简历投递管理、新闻资讯管理、新闻资讯收藏管理、新闻资讯留言管理、学生信息管理、宣传管理、学生管理、职位招聘管理、职位收藏管理、招聘咨询管理、管理员管理。用户的功能等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 大学生就业服务平台管理系统可以提高大学生就业服务平台信息管理问题的解决效率,优化大学生就业服务平台信息处理流程,保证大学生就业服务平台信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理新闻信息,管理大学生就业服务平台信息,包括考试管理,培训管理,投递管理,薪资管理等,可以管理新闻信息。 考试管理界面,管理员在考试管理界面中可以对界面中显示,可以对考试信息的考试状态进行查看,可以添加新的考试信息等。投递管理界面,管理员在投递管理界面中查看投递种类信息,投递描述信息,新增投递信息等。新闻信息管理界面,管理员在新闻信息管理界面中新增新闻信息,可以删除新闻信息。新闻信息类型管理界面,管理员在新闻信息类型管理界面查看新闻信息的工作状态,可以对新闻信息的数据进行导出,可以添加新新闻信息的信息,可以编辑新闻信息信息,删除新闻信息信息。
基于onehot编码+CNN网络实现5位数验证码识别python源码+数据集+详细注释(可作毕设).zip 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我! 基于onehot编码+CNN网络实现5位数验证码识别python源码+数据集+详细注释(可作毕设).zip基于onehot编码+CNN网络实现5位数验证码识别python源码+数据集+详细注释(可作毕设).zip基于onehot编码+CNN网络实现5位数验证码识别python源码+数据集+详细注释(可作毕设).zip基于onehot编码+CNN网络实现5位数验证码识别python源码+数据集+详细注释(可作毕设).zip基于onehot编码+CNN网络实现5位数验证码识别python源码+数据集+详细注释(可作毕设).zip基于onehot编码+CNN网络实现5位数验证码识别python源码+数据集+详细注释(可作毕设).zip基于onehot编码+CNN网络实现5位数验证码识别python源码+数据集+详细注释(可作毕设).zip基于onehot编码+CNN网络实现5位数验证码识别python源码+数据集+详细注释(可作毕设).zip基于onehot编码+CNN网络实现5位数验证码识别python源码+数据集+详细注释(可作毕设).zip
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值