亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 新建 文本文檔.txt

?? 學生系統
?? TXT
?? 第 1 頁 / 共 2 頁
字號:
#include <iostream.h>     // cin 及 cout
#include <malloc.h>       // 用到申請內存函數 malloc() 和釋放內存函數 free()
#include <string.h>		  // 字符串處理
#include <stdio.h>		  // 文件操作(讀文件)
#include <stdlib.h>
#define Y  1
#define N  0

struct  worker                                         
{
	char name[20];                                     
        char sex[10];
	int  num;                                    
        char birthday[100];		               
	char partment[40];                               
        char workyear[10];
	char E-mail[50];                               
	char telphone[10];                                   
	char graduate[20];                                    
	char address[40];                                         
	char duty[20];                                            
	char in_time[20];                                         
};
typedef struct linknode			
{
		struct worker someone;	
		bool flag;
		struct linknode* next;
}nodetype;

struct file
{
       int Dat;
       char num[6];
       char date_t[20];
       char depart[20];
       char duty[20];
       char notice[50];
       int leave_er;
       int come_la;
       int sick_le;
       int affair_le;
       int over_time;
       int out;
       int holiday;
}File_one;




typedef struct LNode
 {
struct File_one data;
struct LNode *next;
}LNode, *pLinkList;

class LinkList {
private:
pLinkList m_pList;
int m_listLength;
public:
LinkList();
~LinkList();
bool InitList ();
bool DestroyList ();
bool ClearList();
bool IsEmpty ();
int GetLength ();
bool GetNode(int position, LNode** node);
int LocateElem(int elem);
bool SetNodeData(int position, int newData);
bool GetNodeData(int position, int &data);
bool InsertNode(int beforeWhich);
bool Insert_Node(int beforeWhich, int data);
bool DeleteNode(int position);
boos load_file( )
int leaveer(int, int);
int comela();
int sickle();
int affairle();
int overtime();
int Out();
int holiday();
};

class List
{
	nodetype* head;

public:
	List();
	List::~List();

	linknode* creatlist(int);				//創建鏈表
	int listlen();							//返回鏈表長度
	nodetype* findnode(int);				//通過查找序號返回節點的指針
	nodetype* find(char c[]);				//通過查找姓名返回節點的指針
	int find2(char c[]);					//通過查找姓名返回節點的序號
	nodetype* insnode(int);					//插入節點
	void delnode(int);						//刪除節點

	nodetype* load();						//初始化:從外部讀入數據

	void readstr(FILE *f,char *string);		//讀行函數
	bool check(char *a, char *b);			//對比兩個字符串是否相等
	void help();							//顯示幫助菜單

	void editworker(nodetype*);				//編輯個人說明

	void dispname();						//顯示所有姓名
	void dispnode(nodetype* p);				//顯示一個職工的所有信息
	void dispworker(nodetype*);				//顯示一個職工的個人說明
				
	
};
Cpp文件:LinkList.cpp
----------------------------------------------------------------------------------------------------------------------------------------
#include <iostream.h>
#include "time.h"
#include "list.h"

List::List()
{
	head = NULL;
}

bool List::check(char *a, char *b)		//對比兩個字符串是否相等
{
	int i;
	int j=strlen(b);
	for(i=0; i<j; i++)
	{
		if(*a==*b)
		{
			a++;
			b++;
		}
		else
			return 0;
	}
	return 1;
}


nodetype* List::creatlist (int n)       //創建鏈表
{
	nodetype *h=NULL, *s, *t;
	int i=1;

	for(int j=0; j<n; j++)
	{
		if(i==1)            //創建第一個節點
		{
			h=(nodetype*)malloc(sizeof(nodetype));
			h->next=NULL;
			t=h;
		}
		else                 //創建其余節點
		{
			s=(nodetype*)malloc(sizeof(nodetype));
			s->next=NULL;
			t->next=s;
			t=s;            //t 始終指向生成的單鏈表的最后一個節點
		}

		i++;
	}

	head=h;
	return h;
}

/*
nodetype* List::creatlist (int n)       //創建鏈表
{
	nodetype *h=NULL;
	int i=1;

	for(int j=0; j<n; j++)
	{
		h=insnode(0);
	}
	head=h;
	return h;
}
*/

void List::readstr(FILE *f,char *string)
{	
	do
	{
						   //①: 先讀入一行文本
		fgets(string, 255, f);  //fgets(): 從文件 f 讀入長度為 255-1 的字符串
						   //		  并存入到 string 中
	} while ((string[0] == '/') || (string[0] == '\n'));

	return;
}

nodetype* List::load()
{
	FILE *fp;
	nodetype *p;
	char c[255];
	int num;
	if((fp=fopen("student.txt", "r"))==NULL)
	{
		cout<<"打開文件失敗"<<endl;
		return 0;
	}
	readstr(fp, c);
	sscanf(c, "The Length Of Link: %d", &num);		//獲取鏈表長度

	p=creatlist(num);								//創建鏈表

	for(int i=0; i<num; i++)
	{
		readstr(fp, c);
		strcpy(p->someone.name, c);
		readstr(fp, c);
		strcpy(p->someone.sex, c);

		readstr(fp, c);
		strcpy(p->someone.num, c);
		readstr(fp, c);
		strcpy(p->someone.birthday, c);
		readstr(fp, c);
		strcpy(p->someone.partment, c);
		readstr(fp, c);
		strcpy(p->someone.workyear, c);
		readstr(fp, c);
		strcpy(p->someone.E-mail, c);

		readstr(fp, c);
		strcpy(p->someone.telphone, c);
		readstr(fp, c);
		strcpy(p->someone.graduate, c);
		readstr(fp, c);
		strcpy(p->someone.address, c);
		readstr(fp, c);
		strcpy(p->someone.duty, c);
		readstr(fp, c);
		strcpy(p->someone.notice, c);

		readstr(fp, c);
		strcpy(p->someone.in_time, c);
	

		p=p->next;
	}

	fclose(fp);

	return p;
}

void List::dispnode(nodetype* p)		//顯示一個職工的所有信息
{
	if(p!=NULL)
	{
		
		dispworker(p);
	}
}

void List::dispname()		//顯示所有職工姓名
{
	nodetype* p=head;
	cout<<"現有的職工:  "<<endl;
	if(p==NULL)
		cout<<"沒有任何職工數據"<<endl;
	while(p!=NULL)
	{
		cout<<"姓名:	"<<p->someone.name;

		p=p->next;
	}
}

int List::listlen()       //返回鏈表長度
{
	int i=0;
	nodetype* p=head;
	while(p!=NULL)
	{
		p=p->next;
		i++;
	}
	return i;
}

nodetype* List::findnode (int i)      //通過查找序號返回節點的指針
{
	nodetype* p=head;
	int j=1;
	if( i>listlen()||i<=0 )          // i 上溢或下溢
		return NULL;
	else
	{
		while( p!=NULL &&  j<i )    //查找第 i 個節點并由 p 指向該節點
		{
			j++;
			p=p->next;
		}
		return p;
	}
}

nodetype* List::find(char c[])      //通過查找姓名返回節點的指針
{
	nodetype* p=head;
	int j=1;
	strcat(c, "\n");				//從外部讀入的字符串末尾都帶了一個換行符
	while( p!=NULL &&  !(check(c, p->someone.name)))    //查找第 i 個節點并由 p 指向該節點	
	{	
		j++;	
		p=p->next;
	}
	return p;
}

int List::find2(char c[])      //通過查找姓名返回節點的序號
{
	nodetype* p=head;
	int j=1;
	strcat(c, "\n");				//從外部讀入的字符串末尾都帶了一個換行符
	while( p!=NULL &&  !(check(c, p->pe.name)))    //查找第 i 個節點并由 p 指向該節點	
	{	
		j++;
		p=p->next;
	}
	return j;
}

nodetype* List::insnode(int i)
{
	nodetype *h=head, *p, *s;
	s=(nodetype*)malloc(sizeof(nodetype));    //創建節點 s
	s->next=NULL;
	if(i==0)           //i=0 時 s 作為該單鏈表的第一個節點
	{
		s->next = h;
		h=s;           //重新定義頭節點
	}
	else
	{
		p=findnode(i);       //查找第 i 個節點,并由 p 指向該節點
		if(p!=NULL)
		{
			s->next=p->next;
			p->next=s;
		}
		else cout<<"輸入的 i 值不正確"<<endl;
	}
	head=h;

	return s;
}

void List::delnode(int i)			//刪除第 i 個節點
{
	nodetype *h=head, *p=head, *s;
	int j=1;
	if(i==1)       //刪除第一個節點
	{
		h=h->next;
		free(p);
	}
	else
	{
		p=findnode(i-1);     //查找第 i-1 個節點,并由 p 指向這個節點
		if(p!=NULL && p->next!=NULL)
		{
			s=p->next;      // s 指向要刪除的節點
			p->next=s->next;
			free(s);
		}
		else
			cout<<"輸入的 i 值不正確"<<endl;
	}
	head=h;
}

void List::editworker(nodetype* p)
{
	char c[100];
	cout<<"請輸入姓名: "<<endl;
	cin>>c;
	strcat(c, "\n");
	strcpy(p->someone.name, c);

	cout<<"請輸入性別:"<<endl;
	cin>>c;
	strcat(c, "\n");
	strcpy(p->someone.sex, c);

        cout<<"請輸入編號:"<<endl;
	cin>>c;
	strcat(c, "\n");
	strcpy(p->someone.num, c);

	cout<<"請輸入生日(格式舉例:1982-1-1): "<<endl;
	cin>>c;
	strcat(c, "\n");
	strcpy(p->someone.birthday, c);

	cout<<"請輸入部門:"<<endl;
	cin>>c;
	strcat(c, "\n");
	strcpy(p->someone.partment, c);

	cout<<"請輸入工作年限:"<<endl;
	cin>>c;
	strcat(c, "\n");
	strcpy(p->someone.workyear, c);

	cout<<"請輸入E-mail"<<endl;
	cin>>c;
	strcat(c, "\n");
	strcpy(p->someone.E-mail, c);

        cout<<"請輸入電話"<<endl;
	cin>>c;
	strcat(c, "\n");
	strcpy(p->someone.telphone, c);

        cout<<"請輸入學歷"<<endl;
	cin>>c;
	strcat(c, "\n");
	strcpy(p->someone.graduate, c);
  
        cout<<"請輸入地址"<<endl;
	cin>>c;
	strcat(c, "\n");
	strcpy(p->someone.address, c);

        cout<<"請輸入職務"<<endl;
	cin>>c;
	strcat(c, "\n");
	strcpy(p->someone.duty, c);

        cout<<"請輸入進入時間"<<endl;
	cin>>c;
	strcat(c, "\n");
	strcpy(p->someone.in_time, c);

	cout<<"編輯個人信息完成!"<<endl;

	dispworker(p);
}



void List::dispworker(nodetype* p)
{
	cout<<"姓名:		"<<p->someone.name;
	cout<<"性別:		"<<p->someone.sex;
	cout<<"電話:		"<<p->someone.telphone;
	cout<<"進公司時間:      "<<p->someone.in_time;
	cout<<"出生日期:	"<<p->someone.birthday;
	cout<<"家庭住址:	"<<p->someone.address;
	cout<<"編號:		"<<p->someone.num;
	cout<<"職務:	        "<<p->someone.duty;
	cout<<"部門:	        "<<p->someone.partment;
	cout<<"工作年限:	"<<p->someone.workyear;
	cout<<"E-mail:	        "<<p->someone.E-mail;
}


void List::help()
{
	cout<<endl<<endl;
	cout<<"----------------------------------------------------------"<<endl;
	cout<<"1:			編輯職工信息"<<endl;           
	cout<<"2:			顯示個人信息"<<endl;
	cout<<"3:			顯示該職工所有信息"<<endl;
	cout<<"4:			幫助菜單"<<endl;
	cout<<"5:			返回上一級菜單"<<endl;
	cout<<"----------------------------------------------------------"<<endl;
}

List::~List()
{
	nodetype *pa=head, *pb;
	if(pa!=NULL)
	{
		pb=pa->next;
		if(pb==NULL)
			free(pa);
		else
		{
			while(pb!=NULL)
			{
				free(pa);
				pa=pb;
				pb=pb->next;
			}
			free(pa);
		}
	}
}

LinkList::LinkList() {
m_pList = NULL;
m_listLength = 0;

InitList();
}

LinkList::~LinkList() {
if (!DestroyList()) {
  DestroyList();
}
}

//初始化,分配一個頭節點。
bool LinkList::InitList() {
if (!(m_pList = new LNode)) {
  return false;
}
m_pList->next = NULL;

return true;
}

//銷毀鏈表。
bool LinkList::DestroyList() {
if (!ClearList()) {
  return false;
}

delete m_pList;

return true;
}

//判斷鏈表是否為空。若為空,返回true,否則返回false。
bool LinkList::IsEmpty() {
if (m_pList->next == NULL) {
  return true;
}
return false;
}

//返回鏈表的中當前節點數。

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色欧美88888久久久久久影院| 亚洲天堂精品在线观看| 色国产综合视频| www.亚洲精品| 97超碰欧美中文字幕| 不卡高清视频专区| 色诱视频网站一区| 欧美在线观看视频在线| 欧美日韩国产在线播放网站| 欧美亚州韩日在线看免费版国语版| 色哟哟日韩精品| 欧美三级视频在线| 91精品国产综合久久精品性色| 精品视频在线视频| 日韩欧美中文一区二区| 久久免费视频色| 国产精品素人一区二区| 亚洲精品成a人| 五月婷婷另类国产| 久久爱另类一区二区小说| 看电视剧不卡顿的网站| 成人午夜在线播放| 欧美亚洲一区三区| 欧美本精品男人aⅴ天堂| 国产日韩欧美精品综合| 亚洲欧美另类图片小说| 日韩电影在线观看电影| 国产精品 日产精品 欧美精品| 99精品一区二区三区| 欧美日韩国产首页| 国产视频一区在线播放| 亚洲精品乱码久久久久久黑人| 亚洲国产欧美日韩另类综合| 久久精品国产一区二区三| 成人性生交大片免费看中文网站| 色综合久久综合网97色综合 | 亚洲国产成人高清精品| 久久99热国产| 91精品1区2区| 久久久亚洲欧洲日产国码αv| 亚洲欧美日韩一区二区三区在线观看| 午夜欧美大尺度福利影院在线看| 激情欧美一区二区| 欧美怡红院视频| 欧美经典三级视频一区二区三区| 午夜精品福利在线| caoporen国产精品视频| 欧美大白屁股肥臀xxxxxx| 一区二区三区四区精品在线视频| 国产老女人精品毛片久久| 欧美丝袜丝交足nylons| 国产精品色噜噜| 免费成人在线视频观看| 在线一区二区三区四区五区| 久久久国产午夜精品| 性欧美大战久久久久久久久| 不卡在线观看av| 欧美一区二区三区精品| 亚洲一区免费观看| 99久久久精品| 国产天堂亚洲国产碰碰| 激情欧美日韩一区二区| 日韩美女天天操| 美腿丝袜亚洲综合| 91麻豆精品国产91久久久久久久久| 亚洲三级久久久| 99精品视频在线观看| 久久九九久精品国产免费直播| 美女网站色91| 日韩欧美资源站| 蜜桃视频在线观看一区二区| 制服丝袜激情欧洲亚洲| 亚洲大片免费看| 欧美色中文字幕| 午夜a成v人精品| 欧美一级在线视频| 美女视频一区二区三区| 日韩精品一区二区在线观看| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美一区二区久久| 蜜桃免费网站一区二区三区| 日韩一卡二卡三卡四卡| 久久精品国产秦先生| 精品久久国产老人久久综合| 精品在线播放免费| 国产欧美精品国产国产专区| 成人性生交大片免费| 中文字幕在线不卡| 欧美午夜精品久久久久久孕妇 | 精品亚洲国内自在自线福利| 欧美不卡视频一区| 国产成人午夜视频| 国产精品久久久久一区二区三区共| heyzo一本久久综合| 亚洲激情图片qvod| 欧美电影影音先锋| 国内成人免费视频| 国产精品国产三级国产普通话三级 | 在线视频国内自拍亚洲视频| 亚洲国产aⅴ天堂久久| 91麻豆精品国产91久久久久久 | 精品一区二区久久久| 久久久久久久久一| 99精品久久只有精品| 亚洲自拍偷拍网站| 欧美电影免费观看高清完整版在线| 毛片一区二区三区| 国产精品午夜春色av| 欧美日韩精品一区二区三区蜜桃 | 精品久久久久久综合日本欧美| 国产91清纯白嫩初高中在线观看 | 亚洲乱码中文字幕综合| 6080午夜不卡| 成人国产精品免费观看视频| 一区二区三区91| 欧美va亚洲va在线观看蝴蝶网| 丁香五精品蜜臀久久久久99网站 | 高清在线成人网| 亚洲风情在线资源站| 久久青草国产手机看片福利盒子| 色综合久久久久综合| 久久不见久久见中文字幕免费| 亚洲免费观看高清在线观看| 日韩精品在线一区二区| 色妹子一区二区| 国产凹凸在线观看一区二区 | 日韩欧美成人午夜| 色噜噜狠狠成人中文综合| 国产麻豆精品theporn| 亚洲综合色婷婷| 亚洲欧美综合色| 久久久噜噜噜久噜久久综合| 欧美一级久久久久久久大片| 91黄色在线观看| 成人av手机在线观看| 经典一区二区三区| 日本欧洲一区二区| 亚洲在线视频网站| 亚洲久本草在线中文字幕| 国产人久久人人人人爽| 日韩欧美一二三| 制服丝袜亚洲播放| 欧美剧情片在线观看| 欧美亚洲国产bt| 欧美综合亚洲图片综合区| 99久久免费精品| jizz一区二区| 色综合欧美在线视频区| 97se亚洲国产综合在线| 91小视频免费观看| 97精品久久久午夜一区二区三区| 成人精品视频网站| heyzo一本久久综合| 成人黄色免费短视频| 99精品热视频| 一本到高清视频免费精品| 色视频成人在线观看免| 欧美在线观看视频一区二区三区| 91福利在线看| 精品视频全国免费看| 欧美日韩久久一区二区| 欧美日韩国产小视频在线观看| 欧美性猛交xxxx黑人交| 欧美日韩精品一区二区| 日韩欧美国产综合| 2023国产精品自拍| 国产精品视频九色porn| 亚洲视频中文字幕| 亚洲成人精品在线观看| 日韩不卡手机在线v区| 韩国欧美国产1区| 成人免费不卡视频| 色综合久久中文字幕综合网| 欧美日韩国产天堂| 欧美变态凌虐bdsm| 亚洲欧洲成人精品av97| 亚洲成人av一区二区三区| 麻豆免费精品视频| 成人久久18免费网站麻豆| 91福利在线播放| 日韩一级大片在线| 国产精品女主播av| 婷婷国产v国产偷v亚洲高清| 欧美精品一区二区三区视频| 中文字幕第一区| 久久网站最新地址| 欧美日韩成人高清| 欧美午夜在线一二页| 欧美成人精精品一区二区频| 国产欧美日韩在线| 性做久久久久久免费观看 | 日韩高清不卡一区二区| 国产真实乱对白精彩久久| 一本久道久久综合中文字幕| 日韩一区二区三区免费看 | 亚洲永久精品大片| 国产一区二区不卡在线| 欧洲亚洲精品在线| 国产精品午夜免费| 精品无人码麻豆乱码1区2区|