2018.08.06

单链表实现通讯录:

头文件部分:

#ifndef _LINKADDRESTLIST_H
#define _LINKADDRESTLIST_H

#define blue "\e[1;34m"
#define yellow "\e[1;33m"
#define red    "\e[0;31m"
#define cyan   "\e[0;36m"
#define purple "\e[0;35m"
#define brown  "\e[0;33m"
#define white  "\e[1;37m"
#define none "\e[0m"
#define SUCCESS 10000
#define FAILURE 10001


struct student                     //单链表单个结点的结构
{
	char name[20];
	char num[20];
	struct student *next;
};
typedef struct student Node;
int studentinit(Node **l);
void welcome();
void menu();
void addinfo(Node *s);
void see(Node *s);
void find(Node *a);
void delete(Node *a);
void change(Node *s);
void  sort(Node *a);
#endif

调用函数:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "Linkaddresslist.h"

int studentinit(Node **l)                     //单链表的初始化
{
	(*l) = (Node *)malloc(sizeof(Node) * 1);
	if(l == NULL)
	{
		return FAILURE;
	}
	(*l)->next = NULL;
	return SUCCESS;
}
void welcome()     //页面显示
{
	system("clear");
	printf("*****************************\n");
	printf(red"欢迎来到帅哥的通讯录.........\n"none);
}
void menu()       //页面显示
{
	printf("\n\n\n**********************\n");
	printf(purple"1、添加信息""             " blue  "2、查看信息\n"none);
	printf(cyan  "3、查找信息""             " red   "4、删除信息\n"none);
	printf(yellow"5、修改信息""             " brown "6、排序\n"none);
	printf(white "7、退出                           \n"none);
	printf("******************************\n");
}
void addinfo(Node *s)          // 单链表的插入,数据的填充,采用尾插法
{
	Node *p = s;
	
	if(s == NULL)
	{
		printf("LINK IS ERROR!\n");
	}
	printf(cyan"请录入联系人的信息\n"none);
	while(1)
	{
		while(p->next)        //使单链表遍历到最后一个结点,以便自己从最后一个插入
		{
			p = p->next;
		}
		Node *q;
		q = (Node  *)malloc(sizeof(Node) * 1);
		scanf("%s%s",q->name, q->num);
		p->next = q;
		q->next = NULL;
		getchar();
		if(getchar() == '\n')
		break;
	}
	system("clear");
}
void see(Node *s)           //数据的显示
{
	
	if(s == NULL)           //入参的判断 
	{
		printf("LINK IS ERROR!\n");
	}
	Node *q = s;
	while(q ->next != NULL)           //在遍历到最够一个结点前,开始显示信息
	{
		q = q->next;
		printf(blue"name:%s num:%s\n"none,q->name, q->num);
	}
}
void find(Node *a)      //通讯录查找功能的实现
{
	if(a == NULL)       //入参判断
	{
		printf("LINK IS ERROR!\n");
	}
	Node *q = a;
	int h;
	printf(brown"想查找的人或者想查找的信息:\n"none);
	scanf("%d",&h);
	switch(h)                //选择按人名查找还是按电话号码查找
	{
		case 0:
			printf(yellow"请输入要查找的人名:\n"none);
			char *p;
			p = (char *)malloc(sizeof(char) * 64);
			scanf("%s",p);
			while(q->next != NULL)
			{
				q = q->next;    //单链表开始遍历;
				if(strcmp(p, q->name) == 0)
				{
					printf(cyan"name:%s num:%s\n"none,q->name, q->num);
					break;
				}
				if(q->next == NULL)   //当单链表遍历到最后,表示没有查找到
				{
					printf(red"查无此人!\n"none);
				}
			}
			free(p);
			break;
		case 1:
			printf(red"请输入要查找的电话号码:\n"none);
			char *k;
			k = (char *)malloc(sizeof(char) * 64);
			scanf("%s",k);
			while(q->next != NULL)
			{
				q = q->next;
				if(k == q->num)
				{
					printf(cyan"name:%s num:%s\n"none,q->name, q->num);
					break;
				}
				if(q->next == NULL)
				{
					printf(red"查无此人!\n"none);
				}
			}
			break;
	}

}
void delete(Node *a)   //删除结点功能的实现
{
	if(a == NULL)     //入参判断
	{
		printf("LINK IS ERROR!\n");
	}
	printf(purple"请输入想删除的人的名字:\n"none);
	char *p; 
	int n = 0, k = 1;
	p = (char *)malloc(sizeof(char) * 64);
	scanf("%s",p);
	Node *q = a;
	Node *m = a;
	Node *t;
 	
	while(q->next != NULL)  //首先查找到删除人的位置
	{
		q = q->next;
		n++;
		if(strcmp(p, q->name) == 0)
		{
				t = q;
				break;
		}
	}
	while(k < n && m != NULL) //由于单链表的单向性,所以从头开始遍历到要删除人的前一个结点位
	{                         //位置
		m = m->next;
		k++;
	}
	m->next = t->next;      //然后执行删除操作,并释放掉删除人的节点空间
	free(t);
	free(p);
	
}
void change(Node *s)   //修改功能的实现
{
	Node *q = s;
	
	printf(brown"请输入想修改的人的名字:\n"none);
	char *p;
	p = (char *)malloc(sizeof(char) * 64);
	scanf("%s",p);
	
	char *v;
	v = (char *)malloc(sizeof(char) * 64);
	while( q->next != NULL)        //首先要遍历查找
	{
		q = q->next;
		if(strcmp(p, q->name) == 0) //当满足条件时,开始修改
			{
				printf(yellow"请输入想修改后的号码:\n"none);
				scanf("%s",v);
				strcpy (q->num, v);
			}
	}
	free(p);

}
void  sort(Node *a)   //排序功能,总体思路是将单链表头结点从第一个节点开始断开;同时用另一个
{                     //变量保存断开后的链表,接下来在断开后的链表依次截取一个结点插入到含
                      //头结点的链表里,怎么插使用排序 方法。。。           
    Node *s = a;                             //s指向排序后节点
	int k = 0, i = 0;
	Node *m = s->next->next, *p, *x ;  //m指向剩下结点,从第二个结点开始
	s->next->next = NULL;     //从第一个结点开始断开
	while(m)
	{
		p = m;                          //p是要排序的节点
		m = m->next;
		x = a;                       //当x遍历到需要插入的位置时,下一次循环要从头开始
		Node *n = s->next;           //n是有序表节点
			if(strcmp(p->name, n->name) < 0)
			{
				p->next = s->next;
				s->next = p;
			}
			else
			{
				while(n != NULL && strcmp(p->name, n->name) > 0)
				{
					n = n->next;
					i++;
				}
				while(k < i )
				{
					x = x->next;
					k++;
				}
				p->next = x->next;
				x->next = p;
			}
	}
}

主函数部分:

#include "Linkaddresslist.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main()
{
	Node *stu = NULL;
	int choice, ret;
	
	ret = studentinit(&stu);     //单链表的初始化
	if(ret == SUCCESS)
	{
		printf("init success!\n");
	}
	else
	{
		printf("init failure!\n");
	}
	system("clear");
	welcome();
	while(1)
	{
		menu();
		scanf("%d",&choice);
		switch(choice)
		{
			case 1:
				addinfo(stu);
				break;
			case 2:
				see(stu);
				break;
			case 3:
				find(stu);
				break;
			case 4:
				delete(stu);
				break;
			case 5:
				change(stu);
				break;
			case 6:
				sort(stu);
				break;
			case 7:
				exit(0);
				break;
		
		
		}
	
	}
	return 0;
}

 

资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建与发布是提升开发效率和项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称和描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本和预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建和发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push package和Deploy/Rollback。每个阶段都可以根据实际需求进行配置和调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率和项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试和部署,从而提高项目的整体质量和可靠性。
year finance_rate cover depth payment insurance credit_ loan digitization score area_id 2011 80.19 98.85 86.24 100.00 72.82 90.30 7.58 0.29 0 2012 150.77 149.35 174.72 136.14 227.70 156.94 111.94 0.30 0 2013 222.14 187.31 280.93 169.95 680.74 156.87 23.03 0.31 0 2014 239.53 237.02 242.78 22.51 725.26 142.88 241.88 0.34 0 2015 278.11 258.98 259.81 268.49 521.32 201.70 374.54 0.36 0 2016 282.22 274.25 281.48 309.09 615.25 190.79 309.94 0.40 0 2017 336.65 305.89 396.05 333.43 785.39 231.81 330.31 0.31 0 2018 377.73 346.33 400.40 356.14 849.62 243.08 440.26 0.44 0 2019 410.28 378.25 439.91 365.22 932.26 282.23 462.23 0.47 0 2020 431.93 395.20 488.68 368.97 945.37 296.03 450.08 0.46 0 2011 24.91 7.47 48.39 55.11 82.08 335.80 39.81 0.13 1 2012 84.43 52.78 111.96 75.43 177.58 886.70 138.91 0.13 1 2013 137.90 95.59 153.55 97.13 413.08 72.86 249.15 0.14 1 2014 164.05 147.22 14.43 134.42 475.79 82.03 255.54 0.14 1 2015 203.76 167.96 158.79 168.47 383.48 122.14 403.67 0.15 1 2016 217.34 185.37 203.17 206.68 501.83 141.41 348.65 0.16 1 2017 256.27 223.54 282.85 217.82 604.28 164.67 316.08 0.12 1 2018 285.79 262.29 278.84 228.89 622.58 166.04 376.06 0.21 1 2019 303.46 284.43 291.12 243.39 647.40 185.35 388.74 0.26 1 2020 318.48 302.46 309.45 255.61 605.03 205.04 387.78 0.22 1 2011 28.89 24.65 30.27 27.51 49.83 224.20 40.35 0.13 2 2012 91.68 75.03 95.44 45.63 158.40 74.75 139.78 0.13 2 2013 146.59 116.37 138.84 73.66 369.88 72.30 260.45 0.14 2 2014 172.56 165.46 114.88 117.47 428.70 53.41 300.84 0.16 2 2015 214.55 185.34 136.04 154.71 332.60 100.99 453.66 0.15 2 2016 229.93 202.00 184.89 195.22 466.55 125.88 404.00 0.17 2 2017 258.50 238.92 249.20 196.40 563.67 141.03 340.10 0.13 2 2018 271.57 269.49 232.31 205.87 561.44 141.03 349.76 0.20 2 2019 293.89 291.45 260.31 224.23 636.92 166.98 362.98 0.17 2 2020 309.39 310.40 275.66 244.52 583.57 198.35 367.40 0.17 2 stata聚类分析代码
06-06
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值