亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

基于C語言如何實現隨機點名器

發布時間:2022-07-28 10:12:06 來源:億速云 閱讀:224 作者:iii 欄目:開發技術

今天小編給大家分享一下基于C語言如何實現隨機點名器的相關知識點,內容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

隨機點名器

基于C語言如何實現隨機點名器

main函數

#include "myList.h"

#define FILENAME "stu.txt"

void menu();//畫面界面;
void userOptions(Node* headNode);//用戶選項

int main(void) {
	SetConsoleTitle(L"隨機抽查系統");
	Node* List = createrList();
	readInfoFromFile(List, FILENAME);

	while (true) {

		menu();

		userOptions(List);



		system("pause");
		system("cls");

	}

	system("pause");

	return 0;
}




void menu() {
	printf("\t\t\t學生點名系統\n");
	printf("\t\t1)開始隨機抽查"
		"\t\t2)添加學生\n"
		"\t\t3)刪除學生"
		"\t\t4)修改學生信息\n"
		"\t\tq)退出\n");
	printf("請輸入你的選項:");

}

void userOptions(Node* List) {
	Student info;

	char choose = '0';

	choose = enter();

	switch (choose) {

	case '1':
		printf("\t\t\t*開始隨機抽查*\n");
		
		seekNode(List, rollCall(LengthNode(List)));
		break;
	case '2':

		printf("\t\t\t\t\t\t已有學生如下\n");
		printfNode(List);
		printf("\t\t\t*添加學生*\n");
		printf("注意請從%d之后開始也就是%d\n", LengthNode(List),LengthNode(List)+1);
		printf("\t\t請輸入學生序號:");

		scanf_s("%d",&info.num);
		
		printf("\t\t請輸入學生學號:");
		scanf_s("%ld", &info.number);
		printf("\t\t請輸入學生姓名:");
		scanf_s("%s", info.name, sizeof(info.name));
		insetNodeByHead(List, info);

		break;
	case '3':
		printf("\t\t\t\t\t\t已有學生如下\n");
		printfNode(List);
		printf("\t\t\t*刪除學生*\n");
		printf("\t\t請輸入學生學號(后兩位即可):");
		scanf_s("%ld", &info.number);
		deleteNodeAppoinNumber(List, info.number);
		break;
	case'4':
		printf("已有學生如下\n");
		printfNode(List);
		printf("\t\t\t*修改學生信息*\n");
		printf("\t\t請輸入學生學號:");
		scanf_s("%ld", &info.number);
		upDataNode(List, info.number);

		break;
	case'q':
		printf("\t\tquit!\n");
		exit(0);
		break;
	default:
		break;




	}
	weiteInfoToFile(List, FILENAME);


}

enter.h

(這個就是我自己寫來玩的,讀取輸入的字符,你們也可以自己弄一個,就可以不用我這個了。但是要記得修改一下引用這個的代碼喔)

#pragma once  //防止重復引用
#include "myList.h" 



//處理寫入
char enter(void); //函數聲明


char enter(void) {
	short count = 1;//次數

	char input = getchar(); // 讀取單個字符
	fflush(stdin);//清空輸入緩存區,防止讀取后,又讀取

	for (int i = 1; i <= 12; i++) {//如果超過誤輸入超過13次,強制退出程序

		if (input == '\n') {//如果讀取的一直是回車,就會執行,否則返回該值
			count++;

			scanf_s("%c", &input, 3);

			fflush(stdin);

			if (count == 5) {
				printf("\n\t\t\t\t\t\t別再調皮了!\n");
				continue;
			}
			else if (count == 11) {
				printf("\n\t\t\t\t\t\t別在摁回車鍵了!最后一次機會了\n");
				continue;

			}
			else if (count == 13) {

				printf("\n\t\t\t\t\t\t程序已強制退出!byebye");
				exit(0);
			}

		}
		else { return  input; }

	}
	return 0;
}

myList.h

#pragma once
#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <time.h>
#include <windows.h>
#include "enter.h"
typedef struct student {//類型
	long int number;
	char name[10];

	int  num;//給定一個序號然后添加一個學生后就自加1;

}Student;

typedef struct Node {
	Student data;
	struct Node* next;

}Node;





//創建鏈表
Node* createrList(void) {

	Node* headNode = (Node*)malloc(sizeof(Node));

	if (headNode) {
		headNode->next = NULL;
	}

	return headNode;
}


//創建結點
Node* createrNode(Student data) {

	Node* newNode = (Node*)malloc(sizeof(Node));

	if (newNode) {
		newNode->data = data;
		newNode->next = NULL;
	}

	return newNode;
}

//插入結點
void insetNodeByHead(Node* headNode, Student data) {

	Node* newNode = createrNode(data);

	newNode->next = headNode->next;
	headNode->next = newNode;

}

//刪除結點
void deleteNodeAppoinNumber(Node* headNode, long int number) {
	Node* posNode = headNode->next;
	Node* posFrontNode = headNode;

	if (posNode == NULL) {
		printf("\t\t表中沒有學生\n");
	}
	else {

		while (posNode->data.number != number) {//沒有找到就繼續找
			posFrontNode = posNode;
			posNode = posNode->next;

			if (posNode == NULL) {//找完最后一個了還沒有
				printf("\t\t表中沒有該學生\n");
				return;
			}
		}

		//找到了,執行刪除操作
		posFrontNode->next = posNode->next;
		free(posNode);
		printf("\t\t刪除完成!");
	}


}

//修改結點
void upDataNode(Node* headNode, long int number) {
	Node* posNode = headNode->next;
	Node* posFrontNode = headNode;

	char choose = '0';

	if (posNode == NULL) {
		printf("\t\t該表中沒有學生\t");
	}
	else {
		while (posNode->data.number != number) {
			posFrontNode = posNode;
			posNode = posNode->next;

			if (posNode == NULL) {
				printf("\t\t表中沒有該學生\n");
				return;

			}
		}

		while (true) {
			printf("\t\t請選擇要修改的選項:1)姓名  2)學號  q)退出!\n");
			printf("\t\t請輸入:");
			choose = enter();


			switch (choose) {
			case '1':
				printf("\t\t請輸入你要更改的名字(原姓名是%s):", posNode->data.name);
				scanf_s("%s", posNode->data.name, sizeof(posNode->data.name));
				system("pause");
				break;
			case '2':
				printf("\t\t請輸入你要更改的學號(原學號是%ld):", posNode->data.number);
				scanf_s("%ld", &posNode->data.number);
				system("pause");
				break;
			case 'q':
				printf("\t\tquit!");
				return;
			default:
				printf("請輸入正確選項:");
				break;
			}
		}

	}




}
//打印結點
void printfNode(Node* headNode) {
	Node* pMove = headNode->next;


	printf("\t\t\t\t\t\t\t\t學號\t\t姓名\n");
	while (pMove != NULL) {
		printf("\t\t\t\t\t\t\t\t%ld\t%s\n", pMove->data.number, pMove->data.name);
		pMove = pMove->next;
	}
	printf("\n");
}


//文件讀
bool readInfoFromFile(Node* headNode, char* fileName) {

	Student data;
	boolean  one = false;
	FILE* fp;
	fopen_s(&fp, fileName, "r");

	if (fp == NULL) {
		fopen_s(&fp, fileName, "w+");

	}

	if (fp == NULL) { return EOF; }

		while (fscanf_s(fp, "%d\t%ld\t%s"
		, &data.num,&data.number, data.name, sizeof(data.name)) != EOF) {

				insetNodeByHead(headNode, data);
	
	}

	if (fp == NULL) { return EOF; }
	fclose(fp);

	return 0;
}

//文件寫
bool  weiteInfoToFile(Node* headNode, char* fileName) {
	
		

	FILE* fp;
	fopen_s(&fp, fileName, "w");
	Node* pMove = headNode->next;
	if (fp == NULL) { return EOF; }
	while (pMove) {
		
		
		fprintf_s(fp, "%d\t\t%ld\t\t%s\n", pMove->data.num,pMove->data.number,pMove->data.name);
	
		pMove = pMove->next;
	}

	if (fp == NULL) { return EOF; }
	fclose(fp);
	return 0;
}



//求出鏈表長度然后返回
int LengthNode(struct Node* headNode) {
	int length = 0;

	struct Node* pMove = headNode->next;

	while (pMove) {
		length++;
		pMove = pMove->next;

	}

	return length;
}



//讀取隨機數然后選出該學生
void seekNode(Node* headNode, long int rand_1) {
	Node* posNode = headNode->next;
	Node* posFrontNode = headNode;

	if (posNode == NULL) {
		printf("\t\t該表中沒有學生\t");
	}
	else
	{	//這里的number改為num
		while (posNode->data.num != rand_1) {
			posFrontNode = posNode;
			posNode = posNode->next;
			if (posNode == NULL) {
				printf("\t\t該表中沒有這這個學號(%ld)的學生\n", rand_1);
				return;
			}
		}


			printf("就決定是你了->");
			printf("\t\t%ld\t%s\n\n\n\n\n", posNode->data.number, posNode->data.name);
		
	}


}


//產生隨機數
long int rollCall(long int length) {
	long int number;
	srand((unsigned)time(NULL));
	number = rand() % length + 1;//33+40;//length+1
	return number;
}

以上就是“基于C語言如何實現隨機點名器”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

崇仁县| 临漳县| 响水县| 马关县| 久治县| 武功县| 毕节市| 咸阳市| 灵宝市| 固镇县| 中方县| 泰兴市| 潞西市| 宁武县| 临朐县| 大连市| 锡林郭勒盟| 华阴市| 阿合奇县| 涿鹿县| 余江县| 永顺县| 晴隆县| 马关县| 湘乡市| 项城市| 颍上县| 长汀县| 景宁| 宣汉县| 温州市| 同心县| 旬邑县| 济源市| 阿尔山市| 大理市| 黑河市| 沙湾县| 吉水县| 嘉峪关市| 东至县|