java链表怎么写入读出文件

求高手指导,用javaio流怎么实现链表的写入和读出文件夹,不知道怎么结合链表和流

1个回答

qq601629983

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
c语言如何把链表数据写入文件?

在写一个通讯录管理系统,然后要把联系人的信息结构体放到链表中,然后将链表里的信息写入文件中,下次打开时还能从该文件读出数据。 链表头指针TEL,结构体中有name,tel,style,mail 四项,存入“telephone.txt"中。 我是这样写的 /*退出程序时将数据写回telephone.txt进行更新*/ void ReadBack() { FILE *TEL = fopen("telephone.txt","wt+"); ID *te = id->next; while (te != NULL) { fwrite(id,sizeof(ID),1,TEL); te = te->next; } fclose(TEL); } 结果文件中是一串乱字 是 屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯屯?f 请给出代码,本人初学,多谢!

c语言怎么把一个双向链表写入文件

用c语言这一个双向链表,然后用fwrite写入文件,用fread读取,这个过程和单链表是一样的吗?

C语言动态链表写入文件

struct Txl { char name[20]; long long tel; struct Txl *next; }; int n; struct Txl *creat(void) { struct Txl *p1,*p2,*head; n=0; p1=p2=(struct Txl*)malloc(LEN); memset(p1,0,sizeof(LEN)); memset(p2,0,sizeof(LEN)); printf("姓名\t"); scanf("%s",&p1->name); fflush(stdin); printf("电话\t"); scanf("%lld",&p1->tel); fflush(stdin); head=NULL; while(p1->tel!=0) { n=n+1; if(n==1)head=p1; else p2->next=p1; p2=p1; p1=(struct Txl*)malloc(LEN); memset(p1,0,sizeof(LEN)); printf("姓名\t"); scanf("%s",&p1->name); fflush(stdin); printf("电话\t"); scanf("%lld",&p1->tel); fflush(stdin); } p2->next=NULL; return(head); } void prin(struct Txl *head){...}//输出。。。 void save(struct Txl *head) { int i; struct Txl *p; FILE *fp; p=head; if((fp=fopen("1.txt","wb"))==NULL) { printf("不能打开文件"); return; } for(i=0;i<n;i++) { if(fwrite(p,LEN,1,fp)!=1) { printf("写入失败"); } p=p->next; } fclose(fp); } void main(){...}

C语言链表与文件 从文件读数据到链表里

#include<stdio.h> #include<stdlib.h> #include<string.h> #include<malloc.h> //定义全局变量 int isEmpty=0;//标志,判断链表是否为空 //!!!定义单链表结构体!!! typedef struct Node{ int NUM;//类型总数 char NAME[100];//各类型名称 int num; //各类型下的货物总数 struct Node*next; }Node; //函数声明 Node*create(int n,Node*L); Node*input(Node*L); Node*output(Node*L); Node*outnum(Node*L); Node*outname(Node*L); Node*current(Node*L); void search(Node*L); void print(Node*L); void searchnum(Node*L); void searchname(Node*L); void display(int n,Node*L); //========新增加的函数======== Node*append(Node*L); //主函数 void main() { //创建文件 FILE*fp; fp = fopen("storehouse.txt","w"); fwrite(); fclose(fp); int x; int n;//初次输入的大小 Node *L; if(!(L=(Node *)malloc(sizeof(Node)))) //分配空间 { printf("\n"); exit(1); } printf("欢迎使用我的仓库管理系统!\n"); while(1) { //主菜单开始 printf("==========================\n"); printf("1.显示货物类型列表\n"); printf("2.增加货物类型\n"); printf("3.删除货物类型\n"); printf("4.货物入库\n"); printf("5.货物出库\n"); printf("6.库存显示\n"); printf("7.退出\n"); printf("==========================\n"); //主菜单结束 printf("选择1-7:"); scanf("%d",&x); switch(x) { case 1:;break; case 2:printf("请输入最初的货物类型数量:\n"); scanf("%d",&n); create(n,L); break; case 3:;break; case 4:;break; case 5:;break; case 6:display(n,L);break; case 7:;break; default:printf("input error!\nplaese input1-7"); } } } =========================== 想要读入货物信息:货物名称 货物价格 所属类型?这个怎么搞! [图片说明](https://img-ask.csdn.net/upload/201805/29/1527585662_34177.png) //函数 //1.创建链表节点 Node*create(int n,Node*L) { Node*pTail=L; L->next=NULL; Node*p; //利用尾插建立单链表 int i; for(i=1;i<=n;i++) { p=(Node*)malloc(sizeof(Node)); if(p==NULL) { printf("申请内存空间失败!\n"); } printf("请输入第%d种类型编号:",i); scanf("%d",&p->NUM); printf("请输入第%d种类型名称:",i); scanf("%s",&p->NAME); printf("请输入第%d种类型库存:",i); scanf("%d",&p->num); putchar('\n'); pTail->next=p; pTail=p; } p->next=NULL; return L; } //货物显示函数 void display(int n,Node*L) { Node*p; p=(Node*)malloc(sizeof(Node)); p=L->next;; int i=0; for(i=0;i<n;i++) //{ //while(p!=NULL) { printf("第%d种类型名称:",p->NUM); printf("%s\n",p->NAME); printf("第%d种类型库存:",p->NUM); printf("%d\n",p->num); putchar('\n'); p=p->next; //} } }

关于c语言读取文件信息到链表,怎么操作?

问题:在读取文件数据到链表时好像出错了,除了"w+"的打开方式会让打印函数在程序运行,其他的打开方式在程序运行后不显示。![图片说明](https://img-ask.csdn.net/upload/201903/16/1552703248_859387.png) ``` #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> #include<malloc.h> struct stu { int id; int age; char name[10]; int score; struct stu *next; }; void printf_stu(struct stu * head)//打印函数 { struct stu *p = head; printf("学生成绩\n"); printf("%-2s %-2s\n", "学号", "成绩"); while (p != NULL) { printf("%d %d\n", p->id, p->score); p = p->next; } } struct stu * create(int n) {//输入链表函数 int i; struct stu *head = NULL, *p, *q = NULL; for (i = 1; i <= n; i++) { if ((p = (struct stu *)malloc(sizeof(struct stu))) == NULL) { printf("不能分配!"); exit(0); } p->next = NULL; printf("第%d个学生的信息:", i); scanf("%d%d", &p->id, &p->score); if (i == 1) head = p; else q->next = p; q = p; } return head; } void open_in(struct stu *head) {//输入文件函数1 FILE *fp; struct stu *p = head; fp = fopen("c://学生信息表.txt", "w"); fprintf(fp, "%s %s\n", "学号", "成绩"); while (p != NULL) { fprintf(fp, "%d %d\n", p->id, p->score); p = p->next; } fclose(fp); } void open_inpp(struct stu *head) {//输入文件函数2 FILE *fp; struct stu *p = head; fp = fopen("c://学生信息表.txt", "a+"); fprintf(fp, "%s %s\n", "学号", "成绩"); while (p != NULL) { fprintf(fp, "4%d 4%d\n", p->id, p->score); p = p->next; } fclose(fp); } struct stu *createlink()//读取文件数据函数 { struct stu *head = (struct stu *)malloc(sizeof(struct stu)); int t, y; struct stu *p; struct stu *q; FILE * fp; p = q = head; fp = fopen("c://学生信息表.txt", "r"); while (fscanf(fp, "%d %d\n", &t, &y) != EOF) { q = (struct stu*)malloc(sizeof(struct stu)); q->id = t; q->score = y; p->next = q; p = q; } p->next = NULL; head = p; return head; } void main() { int n, i,sel; struct stu *head = NULL,*p; for (i = 1; i > 0; i++) { printf("1-输入学生数据 2-添加学生数据\n"); printf("3-打印学生数据"); printf("请输入选择(1-3)\n"); scanf("%d", &sel); switch (sel) { case 3: head = createlink(); printf_stu(head); break; case 2: open_inpp(head); break; case 1: printf("输入n:"); scanf("%d", &n); head = create(n); open_in(head); break; } printf("1-回到上一页 2-结束\n"); scanf("%d", &sel); if (sel > 1) break; } system("pause"); } ```

java中链表的克隆问题

代码如下: ``` import java.util.*; public class Example12_6 { public static void main(String args[]) { LinkedList<String> list1=new LinkedList<String>(); list1.add("A"); list1.add("B"); list1.add("C"); list1.add("D"); list1.add("E"); LinkedList<String> list2 =(LinkedList<String>)list1.clone(); //这里我有两个问题不明白, //第一是带有类型参数的泛型链表这样强制转化不是会擦除吗? //和拿LinkedList直接进行强制转化有区别吗? //第二是LinkedList中的clone方法不是浅复制吗? //那么list2中的元素指向的不也是list1中的元素吗? //那么下面对list1进行洗牌后list2中的元素怎么不变呢? System.out.print("链表中的数据:"); Iterator<String> iter=list1.iterator(); while(iter.hasNext()) { String str=iter.next(); System.out.print(str+" "); } Collections.shuffle(list1); //洗牌 System.out.printf("\n洗牌后链表中的数据:"); iter=list1.iterator(); while(iter.hasNext()) { String str=iter.next(); System.out.print(str+" "); } System.out.printf("\n链表中的数据:"); iter=list2.iterator(); while(iter.hasNext()) { String str=iter.next(); System.out.print(str+" "); } Collections.rotate(list2,2); //向右旋转2步 System.out.printf("\n向右旋转2步后链表中的数据:"); iter=list2.iterator(); while(iter.hasNext()) { String str=iter.next(); System.out.print(str+" "); } } } ``` 本人还是小白一枚,虚心求教。

从txt文件中读取数据存入到链表,即使文件没有内容也会存上数字和乱码

代码如下: ``` contacts* read(char* filename)//把文件读入链表 { FILE* fp; if ((fp = fopen("people.txt","r")) == NULL)//以可读写方式打开文件,如果没有则建立一个 { printf ("文件打开失败!\n"); exit (1); } contacts *head, *q, *p, *h; head = NULL; p = (contacts*)malloc(sizeof(contacts)); if(NULL == p) { printf("内存分配错误"); exit(1); } q = p; //开始时,p和q均指向第1个结点 while (!feof(fp))//创建链表, 并把文件内容输入 { n++; if (n == 1) { head = p; } else { q->next = p; } q = p;//q是最后一个结点 p = (contacts*)malloc(sizeof(contacts)); fscanf(fp,"%d %s %s",&p->no,&p->name,&p->sex); /*int i=0; for(i=0;i<8;i++) { fscanf(fp,"%s",&p->phonenumber[i]); } fscanf(fp,"%s %d %d %d",&p->address,&p->byear,&p->bmonth,&p->bday);*/ }; q->next = NULL;//输入完毕后,q->next为NULL h = head; fclose(fp); return h; } void browse(contacts* head)//显示程序中所有记录的信息。 { while(head)//当head不为空的时候 { printf("\n==================================\ \n序号:%d\ \n姓名:%s 性别:%s",head->no,head->name,head->sex); /*printf("\n电话号码:\n"); int i; for(i=0; i<8; i++) { if(strlen(head->phonenumber[i]) == 0) { continue; } else { printf("%s\n",head->phonenumber[i]); } } printf("住址:%s ",head->address); printf("生日:%d年%d月%d日",head->byear,head->bmonth,head->bday);*/ printf("\n==================================\n"); head = head->next; } } ``` 运行结果 ![图片说明](https://img-ask.csdn.net/upload/201903/02/1551542218_627768.jpg) 为啥会这样。

关于c++类链表读取文本文件的问题

读取时总是读取不了TXT文件的最后一行内容,而且运行到最后程序还会崩溃,这是怎么回事呢? TXT文件内容如下: 1 老王 50 2 小李 65 3 大刘 98 4 天天 10 代码如下: #include<iostream> #include<fstream> #include<string> using namespace std; class student { public: int num; string name; int score; student *next; void creatList(student *& sPeople) { ifstream readFile("F:\\student.txt", ios::in); student *s, *p = NULL; s = new student; readFile >> s->num >> s->name >> s->score; while (!readFile.eof()) { if (sPeople == NULL) sPeople = s; else p->next = s; p = s; s = new student; readFile >> s->num >> s->name >> s->score; } p->next = NULL; delete s; return; } void showList(student *sPeople) { while (sPeople) { cout << "学号:" << sPeople->num << "\t姓名:" << sPeople->name << "\t分数:" << sPeople->score << endl; sPeople = sPeople->next; } } }; int main() { student *sPeople = NULL; sPeople->creatList(sPeople); sPeople->showList(sPeople); }

C语言,我明明把单链表的某个节点删除了,但单链表写入文件时还是会写入一些奇怪的东西?

![图片说明](https://img-ask.csdn.net/upload/201905/22/1558529936_894535.png) ``` #include<stdio.h> #include<stdlib.h> #include<string.h> typedef struct book { long number;//ISBN char name[30];//书名 char auther[30];//作者 char press[30];//出版社 float price;//价格 int exist;//库存 struct book *next; }BOOK; //初始化模块 void Init(BOOK *&b) { b=(BOOK *)malloc(sizeof(BOOK)); //b->exist=0; b->next=NULL; } //查找模块 //按ISBN查找 void Search_number(BOOK *b,long number)//按ISBN查找 { BOOK *p=b->next; while(p) { if(p->number!=number) p=p->next; else break; } if(p&&number==p->number) { printf("您所查找的ISBN为%ld的图书信息如下:\n",number); printf("ISBN\t书名\t\t作者名\t\t出版社名\t价格\t库存\n"); printf("%ld\t%s\t\t%s\t\t%s\t\t%.2f\t%d\n",p->number,p->name,p->auther,p->press,p->price,p->exist); } if(!p) printf("没有找到ISBN为%ld的书籍!\n",number); } //按书名查找 void Search_name(BOOK *b,char *name)//按书名查找 { BOOK *p=b->next; while(p) { if((strcmp(p->name,name)>0||strcmp(p->name,name)<0)) p=p->next; else break; } if(p&&strcmp(p->name,name)==0) { printf("您所查找的书《%s》信息如下:\n",name); printf("ISBN\t书名\t\t作者名\t\t出版社名\t价格\t库存\n"); printf("%ld\t%s\t\t%s\t\t%s\t\t%.2f\t%d\n",p->number,p->name,p->auther,p->press,p->price,p->exist); } else printf("没有找到书名为《%s》的书籍!\n",name); } //图书增加模块 void Add(BOOK *&b) { int flag=0; long number; BOOK *p=b->next,*q=b,*s; printf("\n请输入ISBN:"); scanf("%ld",&number); while(p) { if(p->number==number) { printf("\n您所输入图书已存在,请选择操作:\n"); while(1) { printf("********** 请选择 ****\n"); printf("********** 1.入库 ****\n"); printf("********** 2.退出当前界面 ****\n"); printf("请输入:"); int y; scanf("%d",&y); if(y==1) { printf("\n请输入入库数量:"); int num; while(1) { scanf("%d",&num); if(num<=0) printf("\n输入错误,请重新输入!"); if(num>0) break; } p->exist+=num; printf("入库成功!\n"); break; } else if(y==2) break; else printf("\n输入错误,请重新输入!"); } flag=1; break; } q=p; p=q->next; } if(flag==0) { s=(BOOK *)malloc(sizeof(BOOK)); s->number=number; printf("\n请输入书名:"); scanf("%s",s->name); printf("\n请输入作者名:"); scanf("%s",s->auther); printf("\n请输入出版社名:"); scanf("%s",s->press); printf("\n请输入价格:"); scanf("%f",&s->price); printf("\n请输入入库图书数量:"); scanf("%d",&s->exist); printf("\n"); q->next=s; s->next=NULL; printf("图书增加完成!\n"); } } //图书更新模块 void Update(BOOK *&b) { int flag=0; long number; BOOK *p=b->next,*q=b,*s; printf("\n请输入要更新的图书的ISBN:"); scanf("%ld",&number); while(p) { if(p->number==number) { printf("已找到该图书,请选择操作:\n"); for(int i=0;;i++) { printf(" @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n"); printf(" ! 请选择 !\n"); printf(" ! 1.价格变更 !\n"); printf(" ! 2.出版社变更 !\n"); printf(" ! 3.库存变更 !\n"); printf(" ! 4.退出当前界面 !\n"); printf(" @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n"); printf("请输入:"); int k; scanf("%d",&k); if(k==1) { float price; printf("\n请输入更新后的价格:"); scanf("%f",&price); if(price<=0) printf("\n输入错误,请重新输入!\n"); else { p->price=price; printf("图书信息更新成功!\n"); } } else if(k==2) { char press[30]; printf("\n请输入更新后的出版社:"); scanf("%s",press); strcpy(p->press,press); printf("图书信息更新成功!\n"); } else if(k==3) { int exist; printf("\n请输入更新后的库存:"); scanf("%d",&exist); if(exist==0) { q->next=p->next; free(p); } if(exist<0) printf("\n输入错误,请重新输入!\n"); if(exist>0) { p->exist=exist; printf("图书信息更新成功!\n"); } } else if(k==4) break; else printf("\n输入错误,请重新输入!\n"); } flag=1; break; } q=p; p=q->next; } if(flag==0) { printf("查无此书,是否将此书入库(y/n):"); char ch; scanf(" %c",&ch); if(ch=='y') { s=(BOOK *)malloc(sizeof(BOOK)); s->number=number; printf("请输入书名:"); scanf("%s",s->name); printf("\n请输入作者名:"); scanf("%s",s->auther); printf("\n请输入出版社名:"); scanf("%s",s->press); printf("\n请输入价格:"); scanf("%f",&s->price); printf("\n请输入入库图书数量:"); scanf("%d",&s->exist); printf("\n"); s->next=NULL; q->next=s; printf("图书入库完成!\n"); } } } //图书删除模块 void DelBook(BOOK *&b) { long number; printf("\n请输入要删除图书的ISBN:"); scanf("%ld",&number); BOOK *p=b,*q=b->next; while(q)//查找要删除节点 { if(q->number!=number) { p=q; q=p->next; } else break; } if(q&&number==q->number) { int num; printf("该图书当前库存为:%d,请输入要减少的数量:",q->exist); while(1) { scanf("%d",&num); if(num<=0||num>q->exist) printf("输入错误,请再次输入要减少的数量:"); if(0<num&&num<=q->exist) break; } if(q->exist>num) q->exist-=num; else if(q->exist==num) { //if(!q->next) //p->next=NULL; //else p->next=q->next; free(q); } printf("\n删除成功!\n"); } else { printf("没有该图书,无法删除!\n"); return; } } //删除单链表 void Del(BOOK *&b) { BOOK *pre=b,*p=b->next; while(p!=NULL) { free(pre); pre=p; p=pre->next; } free(pre); } //向book.txt写入数据 void WriteBook(BOOK *b) { BOOK *p=b->next; if(!p) { printf("当前链表为空,即将清空文件数据...\n"); /*当链表为空时,以写 的方式清空文件!*/ FILE *fp; fp=fopen("book.txt","w"); fclose(fp); printf("\n文件清空成功!\n"); return; } else { FILE *fp; if((fp=fopen("book.txt","w"))==NULL) { printf("文件打开失败!\n"); return; } fprintf(fp,"ISBN\t书名\t作者\t出版社\t价格\t库存\n"); while(p) { fprintf(fp,"%ld\t%s\t%s\t%s\t%.2f\t%d\n",p->number,p->name,p->auther,p->press,p->price,p->exist); printf("%ld\t%s\t%s\t%s\t%.2f\t%d\n",p->number,p->name,p->auther,p->press,p->price,p->exist); printf("乱码:%d\n",p->number); p=p->next; } //fprintf(fp,"%ld\t%s\t%s\t%s\t%.2f\t%d\n",p->number,p->name,p->auther,p->press,p->price,p->exist); printf("书籍存储成功!\n"); fclose(fp); } } //从book.txt读取图书信息 BOOK *ReadBook() { FILE *fp; BOOK *head,*p,*q; Init(head); if((fp=fopen("book.txt","r"))==NULL) { printf("文件打开失败!\n"); return head; } else { fgetc(fp); if(!feof(fp)) { char str[1000]; rewind(fp); fgets(str,sizeof(str),fp); //printf("\n%s\n",str); p=(BOOK *)malloc(sizeof(BOOK)); fscanf(fp,"%ld%s%s%s%f%d",&p->number,p->name,p->auther,p->press,&p->price,&p->exist); p->next=NULL; head->next=p; } while(!feof(fp)) { q=(BOOK *)malloc(sizeof(BOOK)); fscanf(fp,"%ld%s%s%s%f%d",&q->number,q->name,q->auther,q->press,&q->price,&q->exist); q->next=NULL; p->next=q; p=p->next; //q->next=NULL; } printf("\n书籍信息获取成功!\n"); fclose(fp); return head; } } //菜单 void menu(BOOK *&b) { while(1) { int x,y; printf(" 小型书店图书信息管理系统 \n"); printf(" @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n"); printf(" ! 主菜单 !\n"); printf(" ! 1.查询图书信息 !\n"); printf(" ! 2.图书信息增加 !\n"); printf(" ! 3.图书信息更新 !\n"); printf(" ! 4.图书信息删除 !\n"); printf(" ! 5.退出程序 !\n"); printf(" @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\n"); printf("请输入:"); scanf("%d",&x); if(x==1) { printf("\n请输入查找方法\n"); printf("1.按ISBN查找\n2.按书名查找\n"); printf("请输入:"); scanf("%d",&y); if(y==1) { long number; printf("请输入要查找书籍的ISBN:"); scanf("%ld",&number); Search_number(b,number); } else if(y==2) { char *name; printf("请输入要查找书籍的书名:"); scanf("%s",name); Search_name(b,name); } else printf("输入错误!\n"); } else if(x==2) Add(b); else if(x==3) Update(b); else if(x==4) DelBook(b); else if(x==5) return; else printf("\n输入错误,请重新输入!\n"); } } //主函数 int main() { BOOK *b; b=ReadBook(); menu(b); WriteBook(b); Del(b); return 0; } ```

关于C语言文件读取和写入

我写一个贪吃蛇的代码,最后要把分数写入一个文件中,然后输出为排行榜。 原来的txt文件里面是10个0(每个0一行),然后第一次游戏结束后,排行榜是第一名是这次的分数,其他全是0。 然后在进行下一次游戏,结束后是排行榜第一的是这次游戏的分数,其他的全是0,第一游戏的分数不见了。 ``` void Rankinglist(){ int m,n,i; FILE*fp1,*fp2; scores[10]=score; fp1=fopen("E:\\1.txt","r"); for(i=0;i<10;i++) fscanf(fp1,"%5.0f",&scores[i]); fclose(fp1); for(m=0;m<=9;m++){ for(n=m+1;n<=10;n++){ if(scores[m]<scores[n]){ scores[m]=scores[m]+scores[n]; scores[n]=scores[m]-scores[n]; scores[m]=scores[m]-scores[n]; } } } if(score!=scores[10]){ Position(60,10); printf("您的成绩登上了排行榜!"); fp2=fopen("E:\\1.txt","w"); for(i=0;i<10;i++){ fprintf(fp2,"%5.0f",scores[i]); } fclose(fp2); } Position(60,12); printf("排行榜"); for(i=0;i<10;i++){ Position(60,13+i); printf("第%d名:%5.0f分",i+1,scores[i]); } } ``` 求大神帮助。

c++读取文件中的链表存取问题

这是一个读取文件中的链表,然后再存进新的链表为本次操作所使用,但是在存到新链表中 ,画红线的p2->next=p1;的时候就会报错。这是一个双向链表,![图片说明](https://img-ask.csdn.net/upload/201604/13/1460519827_356009.png)![图片说明](https://img-ask.csdn.net/upload/201604/13/1460519837_963915.png)

关于c++将文件内容读取到链表中

![图片说明](https://img-ask.csdn.net/upload/201604/18/1460948649_796479.png)![图片说明](https://img-ask.csdn.net/upload/201604/18/1460948658_940680.png)![图片说明](https://img-ask.csdn.net/upload/201604/18/1460948666_439780.png)

用java如何创建一个链表

用java如何创建一个链表,当前节点之前一个节点怎么表示,如果不可以表示的话那么怎么用插入的节点和其他节点比较

通讯录中TXT文件读取问题

``` package in; import java.awt.Container; import java.awt.GridLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.io.IOException; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JPanel; import javax.swing.WindowConstants; public class Demo extends JFrame { /* * 界面设计 * */ public Demo(){ Container c = getContentPane(); //定义一个顶级容器c setAlwaysOnTop(true); //窗体置顶 JPanel jp = new JPanel(); //新建JPanel面板--jp JButton button1 = new JButton("新建联系人"); JButton button2 = new JButton("删除联系人"); JButton button3 = new JButton("编辑联系人"); JButton button4 = new JButton("查找联系人"); JButton button5 = new JButton("显示所有联系人"); JButton button6 = new JButton("保存联系人到本地"); JButton button7 = new JButton("读取本地联系人"); jp.setLayout(new GridLayout(3,4,5,5));//新建网格布局管理器(行数,列数,组件间的水平垂直间距) jp.add(button1); jp.add(button2); jp.add(button3); jp.add(button4); jp.add(button5); jp.add(button6); jp.add(button7); c.add(jp);//将JPanel面板jp添加到顶级容器c中 setSize(600,150); setTitle("*通 讯 录 管 理 系 统*"); setVisible(true); setResizable(false);//窗体大小由程序员决定,用户不能自由改变大小 setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE); /* *按键响应 * * */ button1.addActionListener(new ActionListener(){//添加功能实现 public void actionPerformed(ActionEvent arg0){ Infro.addFunction(); } }); button2.addActionListener(new ActionListener(){//删除功能实现 public void actionPerformed(ActionEvent arg0){ Infro.deleteFunction(); } }); button3.addActionListener(new ActionListener(){//修改功能实现 public void actionPerformed(ActionEvent arg0){ Infro.reditFunction(); } }); button4.addActionListener(new ActionListener(){//查询功能实现 public void actionPerformed(ActionEvent arg0){ try { Infro.searchFunction(); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } }); button5.addActionListener(new ActionListener(){//显示功能实现 public void actionPerformed(ActionEvent arg0){ Infro.showFunction(); } }); button6.addActionListener(new ActionListener(){//保存功能实现 public void actionPerformed(ActionEvent arg0){ try { Infro.writeFunction(); } catch (IOException e) { e.printStackTrace(); } } }); button7.addActionListener(new ActionListener(){//读取功能实现 public void actionPerformed(ActionEvent arg0){ try { Infro.readFunction(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }); } public static void main(String[] args) { // TODO Auto-generated method stub new Demo(); Infro a = new Infro("", "", "", "", "", ""); } } package in; import java.applet.Applet; import java.awt.Graphics; import java.io.BufferedReader; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; import java.io.StringWriter; import java.util.ArrayList; import java.util.Arrays; import java.util.Scanner; import javax.swing.JPanel; class Infro { public String Name; public String Sex; public String Unit; public String Homephone; public String Telephone; public String E_mail; static int index = 0; static ArrayList<Infro> list = new ArrayList(); static int len = list.size(); //构造函数 public Infro(String Name,String Sex,String Unit,String Homephone,String Telephone,String E_mail){ this.Name = Name; this.Sex = Sex; this.Unit = Unit; this.Homephone = Homephone; this.Telephone = Telephone; this.E_mail = E_mail; } public String toString(){ return "姓名:"+Name+"\t性别:"+Sex+"\t单位:"+Unit+"\t住宅电话:"+Homephone +"\t移动电话:"+Telephone+"\tE_mail:"+E_mail; } /* * 添加功能 * */ public static void addFunction(){//添加功能 Infro infro = new Infro("","","","","",""); System.out.println("请输入添加的数据:"); Scanner in = new Scanner(System.in); System.out.println("输入姓名:"); infro.Name = in.next(); System.out.println("输入性别:"); infro.Sex = in.next(); System.out.println("输入单位:"); infro.Unit = in.next(); System.out.println("输入住宅电话:"); infro.Homephone = in.next(); System. out.println("输入移动电话:"); infro.Telephone = in.next(); System.out.println("输入E_mail:"); infro.E_mail = in.next(); list.add(index,infro); index++; if(list.isEmpty()){ System.out.println("数据添加失败啦"); }else{ System.out.println("数据添加成功啦"); len++;//list集合长度加一 // System.out.println(list.get(0).toString()); } System.out.println("是否继续添加?1.是 2.否"); Scanner e=new Scanner(System.in); int e1=e.nextInt(); if(e1==1){ Infro.addFunction(); }else{ return; } } /* * 删除功能 * */ public static void deleteFunction(){ System.out.println("输入要删除的联系人的姓名"); Scanner in_2 = new Scanner(System.in); String d1 = in_2.nextLine(); java.util.Iterator<Infro> it = list.iterator(); while (it.hasNext()){ Infro infro = it.next(); if (infro.Name.equals(d1)){ it.remove(); --index;//一定要加这个,否则当做了删除操作再做添加操作的时候会出现异常(类似于指针,栈) System.out.println("删除完毕"+"此时通讯录记录条数为:" + --len); } } System.out.println("是否继续删除?1.是 2.否"); Scanner e=new Scanner(System.in); int e1=e.nextInt(); if(e1==1){ Infro.deleteFunction(); }else{ return; } } /* * 修改功能 * */ public static void reditFunction(){ System.out.println("输入要修改的通讯录的姓名"); Scanner in_r = new Scanner(System.in); String r1 = in_r.nextLine(); for(int a = 0; a < len;a++){ if(r1.equals(list.get(a).Name)){ System.out.println("输入修改后的性别:"); String Sex_1 = in_r.next(); list.get(a).Sex = Sex_1; System.out.println("输入修改后的单位:"); String Unit_1 = in_r.next(); list.get(a).Unit = Unit_1; System.out.println("输入修改后的住宅电话:"); String Homephone_1 = in_r.next(); list.get(a).Homephone = Homephone_1; System.out.println("输入修改后的移动电话:"); String Telephone_1 = in_r.next(); list.get(a).Telephone = Telephone_1; System.out.println("输入修改后的E_mail:"); String E_mail_1 = in_r.next(); list.get(a).E_mail = E_mail_1; System.out.println("数据修改完毕"); } } System.out.println("是否继续修改?1.是 2.否"); Scanner e=new Scanner(System.in); int e1=e.nextInt(); if(e1==1){ Infro.reditFunction(); }else{ return; } } /* * 查询功能 * */ public static void searchFunction() throws Exception{//查询功能 System.out.println("请选择查询方式: "); System.out.println("1.姓名 2.性别 3.单位 4.住宅电话 5.移动电话 6.E_mail "); Scanner in_0=new Scanner(System.in); int s0=in_0.nextInt(); if(s0==1){ System.out.println("请输入要查询的姓名:"); Scanner in_1 = new Scanner(System.in); String s1=in_1.nextLine(); for(int a= 0; a<len;a++){//切记,,这里不能用a<=list.size(),否则会数组越界异常 if(s1.equals(list.get(a).Name)){ System.out.println(list.get(a).toString()); } } } else if(s0==2){ System.out.println("请输入要查询的性别:"); Scanner in_2 = new Scanner(System.in); String s2=in_2.nextLine(); for(int a= 0; a<len;a++){//切记,,这里不能用a<=list.size(),否则会数组越界异常 if(s2.equals(list.get(a).Sex)){ System.out.println(list.get(a).toString()); } } } else if(s0==3){ System.out.println("请输入要查询的单位:"); Scanner in_3 = new Scanner(System.in); String s3=in_3.nextLine(); for(int a= 0; a<len;a++){//切记,,这里不能用a<=list.size(),否则会数组越界异常 if(s3.equals(list.get(a).Unit)){ System.out.println(list.get(a).toString()); } } } if(s0==4){ System.out.println("请输入要查询的住宅电话:"); Scanner in_4 = new Scanner(System.in); String s4=in_4.nextLine(); for(int a= 0; a<len;a++){//切记,,这里不能用a<=list.size(),否则会数组越界异常 if(s4.equals(list.get(a).Homephone)){ System.out.println(list.get(a).toString()); } } } else if(s0==5){ System.out.println("请输入要查询的移动电话:"); Scanner in_5 = new Scanner(System.in); String s5=in_5.nextLine(); for(int a= 0; a<len;a++){//切记,,这里不能用a<=list.size(),否则会数组越界异常 if(s5.equals(list.get(a).Telephone)){ System.out.println(list.get(a).toString()); } } } else if(s0==6){ System.out.println("请输入要查询的E_mail:"); Scanner in_6 = new Scanner(System.in); String s6=in_6.nextLine(); for(int a= 0; a<len;a++){//切记,,这里不能用a<=list.size(),否则会数组越界异常 if(s6.equals(list.get(a).E_mail)){ System.out.println(list.get(a).toString()); } } } } /* * 显示功能 * */ public static void showFunction(){ for(int i = 0 ;i<len;i++){ System.out.println(list.get(i).toString()); } } /* * 保存功能 * */ public static void writeFunction() throws IOException{ FileWriter writer = new FileWriter("通讯录管理.txt"); for(int i = 0 ;i<len;i++){ String []strwriter = new String[len]; strwriter[i]=list.get(i).toString(); writer.write(strwriter[i]); writer.write("\r\n"); System.out.println("成功写入一行数据到 通讯录管理.txt 中"); } writer.close();//关闭写入流,释放资源 } /* * 读取功能 * */ public static void readFunction() throws IOException{ FileReader reader = new FileReader("通讯录管理.txt"); BufferedReader br = new BufferedReader(reader); String str; while((str = br.readLine()) != null){//每次读取一行文本,判断是否到达文件尾 System.out.println(str); } br.close(); } } ``` 课程设计中遇到了问题… 在运行时输入,可以查询,编辑等操作。可是保存到本地后退出运行,第二次再运行时读取本地联系人,就没办法执行查询操作了。我改了好久还是不行,请各位哥哥姐姐帮忙看一下,拜托~因为还没有学数据库,只能用文件了。 超过20个分屏显示就不要了,因为貌似java没有分屏显示……其他的功能,按姓名排序也希望你们能给些思路,谢谢谢谢 这是题目: 3. 以本班同学的具体数据为背景,设计一个本班同学通讯录(3人) 通讯录要求存储姓名、性别、单位、住宅电话、移动电话、E-mail地址等内容。系统功能要求如下: (1)通讯录记录按姓名排序存放,显示时每屏不超过20个记录,超过时分屏显示。 (2)增加某人的通讯录。 (3)修改某人的通讯录。 (4)删除某人的通讯录。 (5)按多种方式查询符合条件的信息。

读取出来.shp文件的数据后保存在一个链表中,如何将链表内容写入文件

读取出来.shp文件的数据后保存在一个链表中,如何将链表内容写入文件

JAVA链表问题多项式求和

求一个JAVA链表求多项式和的一个实例。两个多项式相加。用JAVA,不用c语言怎么写![图片](https://img-ask.csdn.net/upload/201710/09/1507555665_936965.jpg)

Java该怎么遍历链表数据结构

贴上代码, 我想问一下嵌套类ReverseArrayIterator中的next() 方法该怎样写,才能完成链表 ``` /** * 下压栈链表实现 * * @author maji * @date 2018-7-14 */ public class Stack<Item> implements Iterable<Item> { private Node first; private int N; private class Node { Item item; Node next; } public boolean isEmpty() { return first == null; } public int size() { return N; } public void push(Item item) { Node oldFirst = first; first = new Node(); first.item = item; first.next = oldFirst; N++; } public Item pop() { Item item = first.item; first = first.next; N--; return item; } @Override public Iterator<Item> iterator() { return new ReverseArrayIterator(); } private class ReverseArrayIterator implements Iterator<Item> { private int i = N; @Override public boolean hasNext() { return i > 0; } @Override public Item next() { for (Node x = first; x != null; x = x.next) { return x.item; } } @Override public void remove() { } } } ```

如何使用java生成链表?

package 自习; import java.util.*; class Note { int x; Note next; Note(int a) { x=a; next=null; } } public class LinkList { void put(Note J,int a) { J.next=new Note(a); System.out.println("测试"+J.next.x); J=J.next; } public static void main(String[] args) { Scanner input=new Scanner(System.in); int N,i=1,j; LinkList A=new LinkList(); System.out.println("输入要建立的链表大小N:"); N=input.nextInt(); System.out.println("Please input the "+i+"th number."); j=input.nextInt(); Note X=new Note(j); Note Y=X; for(i=2;i<=N;i++) { System.out.println("输入第"+i"个数:"); j=input.nextInt(); System.out.println("ceshi"+i); A.put(X,j); } for(i=1;i<=N;i++) { System.out.println(Y.x); Y=Y.next; } } } 用以上代码为什么生成的链表里最多只有两个元素?如果是每次调用A.put(X,j);的问题,那么怎样解决呢!在不用 for(i=2;i<=N;i++) { System.out.println("输入第"+i"个数:"); j=input.nextInt(); X.next=new Note(j); X=X.next; } 替换的情况下。

java中的链表类的remove问题

新人初学java,有些基本问题不是很懂,求教各位,谢谢 java中的LinkedList这个链表类中有这样一个方法,removefirst方法,含义是删除,并且返回链表的第一个元素,我想问下各位,是不是只要是删除了第一个元素,那么后面的第二个元素会顶到原来第一个元素的位置上,当我第二次调用这个方法时,相当于删除了链表的第一个元素(原来的第二个元素)? 谢谢各位了

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

程序员请照顾好自己,周末病魔差点一套带走我。

程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

点沙成金:英特尔芯片制造全过程揭密

“亚马逊丛林里的蝴蝶扇动几下翅膀就可能引起两周后美国德州的一次飓风……” 这句人人皆知的话最初用来描述非线性系统中微小参数的变化所引起的系统极大变化。 而在更长的时间尺度内,我们所生活的这个世界就是这样一个异常复杂的非线性系统…… 水泥、穹顶、透视——关于时间与技艺的蝴蝶效应 公元前3000年,古埃及人将尼罗河中挖出的泥浆与纳特龙盐湖中的矿物盐混合,再掺入煅烧石灰石制成的石灰,由此得来了人...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

外包程序员的幸福生活

今天给你们讲述一个外包程序员的幸福生活。男主是Z哥,不是在外包公司上班的那种,是一名自由职业者,接外包项目自己干。接下来讲的都是真人真事。 先给大家介绍一下男主,Z哥,老程序员,是我十多年前的老同事,技术大牛,当过CTO,也创过业。因为我俩都爱好喝酒、踢球,再加上住的距离不算远,所以一直也断断续续的联系着,我对Z哥的状况也有大概了解。 Z哥几年前创业失败,后来他开始干起了外包,利用自己的技术能...

C++11:一些微小的变化(新的数据类型、template表达式内的空格、nullptr、std::nullptr_t)

本文介绍一些C++的两个新特性,它们虽然微小,但对你的编程十分重要 一、Template表达式内的空格 C++11标准之前建议在“在两个template表达式的闭符之间放一个空格”的要求已经过时了 例如: vector&lt;list&lt;int&gt; &gt;; //C++11之前 vector&lt;list&lt;int&gt;&gt;; //C++11 二、nullptr ...

优雅的替换if-else语句

场景 日常开发,if-else语句写的不少吧??当逻辑分支非常多的时候,if-else套了一层又一层,虽然业务功能倒是实现了,但是看起来是真的很不优雅,尤其是对于我这种有强迫症的程序"猿",看到这么多if-else,脑袋瓜子就嗡嗡的,总想着解锁新姿势:干掉过多的if-else!!!本文将介绍三板斧手段: 优先判断条件,条件不满足的,逻辑及时中断返回; 采用策略模式+工厂模式; 结合注解,锦...

深入剖析Springboot启动原理的底层源码,再也不怕面试官问了!

大家现在应该都对Springboot很熟悉,但是你对他的启动原理了解吗?

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

为什么你不想学习?只想玩?人是如何一步一步废掉的

不知道是不是只有我这样子,还是你们也有过类似的经历。 上学的时候总有很多光辉历史,学年名列前茅,或者单科目大佬,但是虽然慢慢地长大了,你开始懈怠了,开始废掉了。。。 什么?你说不知道具体的情况是怎么样的? 我来告诉你: 你常常潜意识里或者心理觉得,自己真正的生活或者奋斗还没有开始。总是幻想着自己还拥有大把时间,还有无限的可能,自己还能逆风翻盘,只不是自己还没开始罢了,自己以后肯定会变得特别厉害...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

【阿里P6面经】二本,curd两年,疯狂复习,拿下阿里offer

二本的读者,在老东家不断学习,最后逆袭

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

《经典算法案例》01-08:如何使用质数设计扫雷(Minesweeper)游戏

我们都玩过Windows操作系统中的经典游戏扫雷(Minesweeper),如果把质数当作一颗雷,那么,表格中红色的数字哪些是雷(质数)?您能找出多少个呢?文中用列表的方式罗列了10000以内的自然数、质数(素数),6的倍数等,方便大家观察质数的分布规律及特性,以便对算法求解有指导意义。另外,判断质数是初学算法,理解算法重要性的一个非常好的案例。

《Oracle Java SE编程自学与面试指南》最佳学习路线图(2020最新版)

正确选择比瞎努力更重要!

面试官:你连SSO都不懂,就别来面试了

大厂竟然要考我SSO,卧槽。

微软为一人收购一公司?破解索尼程序、写黑客小说,看他彪悍的程序人生!...

作者 | 伍杏玲出品 | CSDN(ID:CSDNnews)格子衬衫、常掉发、双肩包、修电脑、加班多……这些似乎成了大众给程序员的固定标签。近几年流行的“跨界风”开始刷新人们对程序员的...

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

我说我懂多线程,面试官立马给我发了offer

不小心拿了几个offer,有点烦

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

立即提问
相关内容推荐