VScode中配置C++,codeRunner插件中设置解决c中无法输入的问题。
刚开始记录会有点细节。
练手小项目:简易计算器
1.设置三个变量接收用户输入的表达式,两个float型,一个char型
2.检查格式并进行运算然后输出,通过逻辑判断语句,判断输入的字符变量,然后进行运算,输出结果,(注意不能对0进行除法和取余操作)
3.运行文件
练手小项目:简易通讯录
打印乱码问题,encodeing中UTF-8和gb2312转换
C语言中相关知识的复习
c中“->”的意思
“->”是一个整体,它是用于指向结构体子数据的指针,用来取子数据。
换种说法,如果我们在C语言中定义了一个结构体,然后申明一个指针指向这个结构体,那么我们要用指针取出结构体中的数据,就要用到“->”。
问题中的p=p->next ,意思是将p指向的一个结构体实例中的自数据next赋值给p。
最后按名字排序中会用到冒泡排序,在此处复习
原理:
1.比较相邻的两个元素,如果第一个比第二个大,就交换它们两个。
2.对每一对元素做上述工作,从开始第一对到结尾最后一对,此时,最大的应该在最后一个
3.针对所有元素重复上述步骤,除了最后一个
4.对越来越少的元素重复,直到没有可以比较的
sizeof的用法
sizeof运算符不是函数,是一个运算符,它主要求一个类型或一个变量所占内存的大小,同时sizeof运算符不会进行复制操作
关于指针的复习
sizeof(s)/sizeof(s[0])的解释
sizeof(s)是一个数组总共的字节数,sizeof(s[0]就是一个元素占的字节数,这么一除就是这个数组的长度了~
此次简易通讯录涉及了数组,结构体,指针等概念
源代码
#define _CRT_SECURE_NO_WARNINGS
#define MAX_PERSON 1000
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct Person{
char name[1024];
char tel[1024];
}Person;
typedef struct AddressBook {
Person persons[MAX_PERSON];
int size;
}AddressBook;
void init(AddressBook* addressbook) {
addressbook->size = 0;
}
void addPerson(AddressBook* addressbook){
printf("新增联系人\n");
int cursize = addressbook->size;
if (cursize >= MAX_PERSON){
printf("通讯录已满,增加失败!\n");
}
Person* p = &addressbook->persons[cursize];
printf("请输入联系人姓名:");
scanf("%s", p->name);
printf("请输入联系人电话:");
scanf("%s", p->tel);
printf("新增联系人成功!\n");
addressbook->size++;
}
void findPerson(AddressBook* addressbook){
printf("按照姓名查找联系人\n");
printf("请输入要查找的姓名: ");
char name[1024] = { 0 };
scanf("%s", name);
for (int i = 0; i < addressbook->size; i++) {
Person* p = &addressbook->persons[i];
if (strcmp(name, p->name) == 0) {
printf("[%d]\t\t%s\t\t%s\n", i, p->name, p->tel);
}
}
printf("查找联系人完成!\n");
}
void delPerson(AddressBook* addressbook){
printf("删除联系人\n");
printf("请输入要删除的联系人的编号: ");
int id = 0;
scanf("%d", &id);
if (id < 0 || id >= addressbook->size) {
printf("您输入的编号有误!\n");
return;
}
if (id == addressbook->size - 1){
addressbook->size--;
printf("删除成功!\n");
return;
}
addressbook->persons[id] = addressbook->persons[addressbook->size - 1];
addressbook->size--;
printf("删除成功!\n");
}
void updatePerson(AddressBook* addressbook){
printf("更新联系人\n");
printf("请输入要更新的联系人的编号: ");
int id = 0;
scanf("%d", &id);
if (id < 0 || id >= addressbook->size) {
printf("您输入的编号有误!\n");
return;
}
Person* p = &addressbook->persons[id];
printf("请输入联系人姓名:");
scanf("%s", p->name);
printf("请输入联系人电话:");
scanf("%s", p->tel);
printf("更新联系人成功!\n");
}
void printPerson(AddressBook* addressbook){
printf("查所有联系人:\n");
for (int i = 0; i < addressbook->size; i++) {
Person* p = &addressbook->persons[i];
printf("[%d]\t\t%s\t\t%s\n", i, p->name, p->tel);
}
printf("共计 [%d] 条记录\n", addressbook->size);
}
void clearPerson(AddressBook* addressbook){
for (int i = 0; i < addressbook->size; i++) {
addressbook->size--;
if (addressbook->size == 0){
break;
}
}
printf("清空成功\n");
}
void sortPerson(AddressBook* addressbook){
if (addressbook->size <= 0){
printf("通讯录中没有联系人,请添加!\n");
}
int i = 0;
int j = 0;
for (i = 0; i<addressbook->size - 1; i++)
{
for (j = 0; j<addressbook->size - i - 1; j++)
{
if (strcmp(addressbook->persons[j].name, (addressbook->persons[j + 1]).name)>0)
{
Person tmp = addressbook->persons[j];
addressbook->persons[j] = addressbook->persons[j + 1];
addressbook->persons[j + 1] = tmp;
}
}
printf("排序成功!\n");
}
}
int menu(){
printf("=====================\n");
printf(" 1. 新增联系人\n");
printf(" 2. 查找联系人\n");
printf(" 3. 删除联系人\n");
printf(" 4. 修改联系人\n");
printf(" 5. 查看所有联系人\n");
printf(" 6. 清空所有联系人\n");
printf(" 7. 以名字排序所有联系人\n");
printf(" 0. 退出\n");
printf("=====================\n");
printf(" 请输入您的选择:");
int choice = 0;
scanf("%d", &choice);
return choice;
}
typedef void(*Func)(AddressBook*);//这是一个函数指针,指向一个函数。参数类型是结构体指针
AddressBook addressbook;//定义一个全局变量,是结构体变量
int main()
{
Func funcs[] = {
NULL,
addPerson,
findPerson,
delPerson,
updatePerson,
printPerson,
clearPerson,
sortPerson,
};
init(&addressbook);
while (1){
int choice = menu();
if (choice == 0){
printf("GoodBye!!!");
break;
}
if (choice<0 || choice>sizeof(funcs) / sizeof(funcs[0])){
printf("您的输入无效!\n");
continue;
}
funcs[choice](&addressbook);
}
system("pause");
return 0;
}