Visual Studio 的c++中的system("pause");暂停,在Xcode中类似作用的是什么?

Visual Studio 的_c++中的system("pause");_暂停,在Xcode中类似作用的是什么?

Xcode内!!

_

#include <iostream>

int main ()
{
    system ("puase");
    std :: cout << "omg!\n" ;
}

_

运行显示如下

_

图片说明

c++

2个回答

可以这样写
printf("press any key to continue......");
getchar();

weixin_46227440
MULESAGLE emmm可以是可以。不过现在还不知道啥意思。。以后再看。谢谢大佬
2 个月之前 回复

Xcode里面你用的是puase,正确的是pause。
或者加一句#include

weixin_46227440
MULESAGLE 回复Programming NOOB: emmm那个大佬的方法可以。
2 个月之前 回复
qq_46208927
Programming NOOB 回复MULESAGLE: 那我就不知道了,你在前面加上一句#include<cstdio>可能可以。
2 个月之前 回复
weixin_46227440
MULESAGLE emmm我刚刚试了一下也是一样。command not found
2 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Visual Studio 的c++中的system("pause");暂停,在Xcode中类似作用的是什么?
Visual Studio 的_c++中的system("pause");_暂停,在Xcode中类似作用的是什么? ## Xcode内!! _ ``` #include <iostream> int main () { system ("puase"); std :: cout << "omg!\n" ; } ``` _ 运行显示如下 _ ![图片说明](https://img-ask.csdn.net/upload/202001/27/1580107045_139220.png)
VS2017使用时为什么非要加getchar或者system("pause")才能停止
我前段时间使用VS2017时写一段代码如下: #include<stdio.h> int main(void) { printf("aaaaa!\n"); return 0; } 可以直接运行,不闪屏,现在使用直接闪屏,而且还必须添加getchar或者system("pause"); 才能正常运行,很难受,求解怎么才能可以新建工程而不需要getchar或者syste m(“pause”) 以前有个win32控制台程序,现在怎么没有了?真的很烦这东西,希望大神指点迷津!
Visual Studio 2019:RangeChecks 检测代码检测到超出范围的数组访问。
写了一个关于抽取学号的程序,如下: ```C++ #include<iostream> #include<fstream> #include<cstring> #include<sstream> #include<iomanip> #include<algorithm> #include<cstdio> #include<ctime> #include<cstdlib> using namespace std; const string PASSWORD = "070714"; int a, j, k, i, co = 0; int arr[55] = {}; char m[200] = {}; string in = "", n = ""; void instructions() { cout << setw(60) << "使用说明"; cout << "重启程序请输入“重启”,关闭程序请输入“退出”。" << endl; cout << "输入一个小于班级人数的数字,将输出一些随机数。" << endl; cout << "输入记事本模式以进入记事本模式,此时你可以输入文本,按Enter键确定。" << endl; cout << "输入打开记事本以查看记事本的内容。" << endl; cout << "\n\n\n还有彩蛋等你来试!\n\n\n"; system("pause"); } void show() { system("cls"); system("color F1"); cout << setw(50) << "抽奖程序" << setw(55) << "[Version 1.6]" << endl; cout << setw(60) << "重启程序请输入“重启”,关闭程序请输入“退 出”。" << endl; cout << "请输入人数:"; } int getrand() { srand(time(0)); //随机种子 int a; a = rand() % 1000 + 1; while (a >= 1000)a -= 55; return a; } int main() { show(); arr[55] = {}; m[200] = {}; a = i = j = k = co = 0; system("start osk"); cin >> in; cout << endl; if (in == "退出") { exit(0); } else if (in == "重启") { system("start choujiang.exe"); exit(1); } else if (in == "打开记事本") { ifstream in; in.open("NotePad.lpr"); while (in >> m)in >> m; cout << m << endl; in.close(); main(); } else if (in == "记事本模式") { system("cls"); ofstream out; system("color F4"); cout << setw(70) << "记事本模式" << endl; out.open("记事本.lpr"); cin >> n; out << n; out.close(); cout << "成功!" << endl; system("pause"); system("cls"); main(); } else if (in == PASSWORD) { cout << "管理员模式" << endl; system("pause"); system("cls"); show(); cin >> in; system("cls"); show(); cout << endl << "中奖号码是" << in << "号" << endl; system("pause"); main(); } else { stringstream ss; ss << in; ss >> i; } if (i > 55) { cout << "人数超过55!!!" << endl; system("pause"); system("cls"); main(); } while (j <= i - 1) { a = getrand(); while (co <= j) { if (a == arr[j]) continue; else arr[j + 1] = a; j++; } } sort(arr, arr + i - 1); for (int z = 0; z < i; z++)cout << "中奖号码是" << arr[z] << "号" << endl; system("pause"); main(); } 报错图片:![图片说明](https://img-ask.csdn.net/upload/202001/25/1579938675_183844.png)
线性表结构的实现,内心迷乱,希望能得到帮助
#include<stdio.h> #include <stdlib.h> #define ERROR 0 #define OK 1 typedef int Status; typedef int Elemtype; typedef struct node { Elemtype elem[LIST_SIZE]; int length; }Sqlist; typedef int Elemtype; typedef int Status; typedef struct LNode{ Elemtype data; struct LNode *next; }LNode,*Linklist; Status LengthList(Linklist *L); Status create(Sqlist *L,int n); Status Findlen1(Sqlist *L); Elemtype GetElem(Sqlist *L, int n); int LocateElem(Sqlist *L, int n); Status ListInsert_Sq(Sqlist *L,int i,int x); Status LisDele_Sq(Sqlist *L,int i); int Printlist(Sqlist* L); Status Init_linklist(Linklist *L); void Creat_Linklist(Linklist *L,int n); Status LengthList(Linklist *L); Status Get_Linklist(Linklist *L,int i,Elemtype *e); Status Locate_Linklist(Linklist *L,Elemtype e); Status Insert_Linklist(Linklist *L,int i,Elemtype e); Status Delete_Linklist(Linklist *L,int i,Elemtype *e) ; void Display(Linklist *L) ; void menu1(); void menu2(); int main() { int x; while(1) { system("cls"); printf("\n\n\n\n\n\n\n\n"); printf("\t\t\t\t\t1:顺序表\n"); printf("\t\t\t\t\t2:链表\n"); printf("\t\t\t\t\t3:退出\n"); printf("\n\t\t\t\t\t请输入您的选择(1-3)=:"); scanf("%d",&x); switch(x) { case 1:menu1(); break; case 2:menu2(); break; case 3:return 0;break; default:printf("error");return 1; break; } printf("\n"); system("pause"); } return 0; } Status create(Sqlist *L, int n) { int i; if(n>LIST_SIZE) return ERROR; for(i=0;i<n;i++) { printf("请输入第%d个数据的值:", i+1); scanf("%d", &L->elem[i]); } L->length=n; return OK; } Status Findlen1(Sqlist *L) {return (L->length);} Elemtype GetElem(Sqlist *L, int n) { { if (n<1 || n>L->length) { return ERROR; } return L->elem[n - 1]; } } int LocateElem(Sqlist *L, int n) //4 {int i; for(i=0;i<=L->length;i++) if(L->elem[i]==n) return i+1; else return 0; } Status ListInsert_Sq(Sqlist *L,int i,int x) //5 {int j; if (i<1||i>L->length +1) return ERROR; if(L->length>100) return ERROR; for(j=L->length-1;j>=i-1;j--) L->elem[j+1]=L->elem[j]; L->elem[i-1]=x; ++(L->length); return OK; } Status LisDele_Sq(Sqlist *L,int i) //6 {int j; if ((i<1)||(i>L->length)) return ERROR; for(j=i;j<=L->length-1;j++) L->elem[j-1]=L->elem[j]; --L->length; return OK; } int Printlist(Sqlist* L) //7 { int j; for (j = 0; j <= L->length - 1; j++) { printf("第%d个数据为%d\n", j + 1, L->elem[j]); } return OK; } Status Init_linklist(Linklist *L) { *L=(Linklist)malloc(sizeof(LNode)); if(!(*L)) { return ERROR; } (*L)->next=NULL; return OK; } void Creat_Linklist(Linklist *L,int n) { Linklist p,q; int i; p = *L; for(i=0;i<n;i++) { printf("请输入链表第%d个元素:",i); q=(Linklist)malloc(sizeof(LNode)); scanf("%d",&q->data); p->next=q; p=q; } p->next=NULL; } Status LengthList(Linklist *L) { int i=0; Linklist p,q; p = *L; if(p->next==NULL) return ERROR; while(p->next!=NULL) { i++; p=p->next; } return i; } Status Get_Linklist(Linklist *L,int i,Elemtype *e) { int j=1; Linklist p,q; p = *L; if(i<1||!p->next||i>LengthList(L)) { return ERROR; } while(j<=i&&p) { p=p->next; j++; } if(j-1==i) { *e=p->data; return OK; } else return ERROR; } Status Locate_Linklist(Linklist *L,Elemtype e) { int i=1; Linklist p,q; p = (*L)->next; while(p->data!=e&&p) { p=p->next; i++; } if(p->data!=e) return -1; else return i; } Status Insert_Linklist(Linklist *L,int i,Elemtype e) { int j=1; Linklist p,q; p = *L; if(i<1||!p->next||i>LengthList(L)) { return ERROR; } while(p&&j<i) { p=p->next; j++; } q=(Linklist)malloc(sizeof(LNode)); q->data=e; q->next=p->next; p->next=q; return OK; } Status Delete_Linklist(Linklist *L,int i,Elemtype *e) { int j=1; Linklist p,q; p = *L; if(i<1||!p->next||i>LengthList(L)) { return ERROR; } while(j<i&&p->next) { p=p->next; j++; } q=p->next; *e=q->data; p->next=q->next; free(q); return OK; } void Display(Linklist *L) { LNode *p; p=(*L)->next; while(p) { printf("%d ",p->data); p=p->next; } printf("\n"); } menu1() { int y,n; Sqlist L; Status T; while(1) { system("cls"); printf("\n\n\n\n\n\n\n\n"); printf("\t\t\t\t\t1:创建顺序线性表\n"); printf("\t\t\t\t\t2:求顺序线性表的长度\n"); printf("\t\t\t\t\t3:按序号取顺序表元素\n"); printf("\t\t\t\t\t4:按值查找顺序表\n"); printf("\t\t\t\t\t5:插入元素\n"); printf("\t\t\t\t\t6:删除元素\n"); printf("\t\t\t\t\t7:输出顺序线性表\n"); printf("\t\t\t\t\t8:返回\n"); printf("\t\t\t\t\t\t请输入您的选择(1-8)=:"); scanf("%d",&y); if(y==8) break; switch(y) { case 1: system("cls"); printf("请输入你要创建的线性表的长度:"); scanf("%d",&n); T=create(&L,n); if(T==ERROR) printf("创建失败,线性表长度超限!!"); else printf("创建线性表成功!!"); system("pause"); break; case 2:system("cls"); Status a; a=Findlen1(&L); printf("您所建线性表长度为%d\n",n); system("pause"); break; case 3:system("cls"); int b; printf("请输入你想找的数据的序号: "); scanf("%d", &n); b = GetElem(&L, n); printf("该序号的数据为%d\n", b); system("pause"); break; case 4:system("cls"); printf("请输入你想找的值:"); scanf("%d", &n); b=LocateElem(&L,n); if (b == 0) printf("线性表中没有该值\n"); else printf("该值在线性表中的第%d位\n", b); system("pause"); break; case 5:system("cls"); int C;int x; printf("请输入你想在哪一个元素前面插入:"); scanf("%d",&n); printf("请输入你想插入的数据:"); scanf("%d",&x); C= ListInsert_Sq(&L,n,x); if(C==1) printf("插入成功"); else printf("插入失败"); system("pause"); break; case 6:printf("请输入您想删除的数字:"); scanf("%d",&n); C=LisDele_Sq(&L,n); if(C==1) printf("删除成功"); else printf("删除失败"); system("pause");break; case 7:system("cls"); Printlist(&L); system("pause"); break; default:printf("error"); break; } printf("\n"); system("pause"); } return 1; } menu2(){ int z; while(1) { system("cls"); printf("\n\n\n\n\n\n\n\n"); printf("\t\t\t\t\t1:创建链式线性表\n"); printf("\t\t\t\t\t2:求链式线性表的长度\n"); printf("\t\t\t\t\t3:按序号取链表元素\n"); printf("\t\t\t\t\t4:按序号取链表元素\n"); printf("\t\t\t\t\t5:插入元素\n"); printf("\t\t\t\t\t6:删除元素\n"); printf("\t\t\t\t\t7:输出链式线性表\n"); printf("\t\t\t\t\t8:返回\n"); printf("\t\t\t\t\t\t请输入您的选择(1-8)=:"); scanf("%d",&z); if(z==8) break; switch(z) { case 1: printf("这里是创建链式线性表"); int n,num,e,value; Linklist L; value=Init_linklist(&L); if(value) printf("单链表初始化成功!\n"); else return ERROR; printf("请输入单链表的长度:") ; scanf("%d",&n); Creat_Linklist(&L,n); printf("单链表中各元素的值为:"); Display(&L);break; case 2:printf("这里是求链式线性表的长度"); break; case 3: int n,num,e,value; printf("这里是按值取链表元素"); printf("\n\n请输入要查找的值e= "); scanf("%d",&num); value=Locate_Linklist(&L,num); if(value>0) printf("该元素在线性表的位序位:%d",value); else printf("\n无该值,查找失败!"); break; case 4: int n,num,e,value; printf("这里是按序号取链表元素"); printf("\n\n请输入要查找的位置:"); scanf("%d",&n); value=Get_Linklist(&L,n,&e); if(value) printf("单链表中第%d位的值为%d",n,e); else printf("\nerror!") ; break; case 5: int n,num,e,value; printf("这里是插入元素"); printf("\n请输入插入的位置:"); scanf("%d",&n); printf("请输入插入的元素:"); scanf("%d",&num); Insert_Linklist(&L,n,num); printf("进行插入操作后\n单链表中各元素的值为:"); Display(&L);break; case 6: int n,num,e,value; printf("这里是删除元素"); printf("\n\n请输入删除的位置:"); scanf("%d",&n); Delete_Linklist(&L,n,&e); printf("被删除元素的值为:%d",e); printf("\n进行删除操作后\n单链表中各元素的值为:"); Display(&L); break; case 7:printf("这里是输出链式线性表"); printf("单链表中各元素的值为:"); Display(&L);break; default:printf("error"); break;} printf("\n"); system("pause"); return 1; } }
既然Complex c=a+b不能实现,那要怎么进行两个对象的相加,只能用函数吗?还有为什么可以直接e=a,对象之间可以不用复制构造函数直接复制的吗?
![图片说明](https://img-ask.csdn.net/upload/202003/26/1585216030_672253.png) 只关注最后几行就好前面都是与问题无关的 ``` #include <iostream> using namespace std; /* run this program using the console pauser or add your own getch, system("pause") or input loop */ /*6. 更加完整建立一个复数类 Complex,要求 a. 含两个私有数据成员:real, imaginary: float b. 具有三种构造函数:a.不带参数构造: 0+0i b.以实部和虚部构造 c.拷贝构造函数 c.公有成员函数包括如下功能: 输出这个复数 与另一复数的加法函数,要求函数原型为 complex add(complex c); 判断与另一复数是否相等 要求函数原型为bool isEqual(complex c); 在main函数中,输入两个复数,判断两个复数是否相等(实部和虚部要分别相等),然后两者相加之和赋值给一个新的复数,并输出 思考:基于上面的Complex类,有如下main函数能否通过运行,有那些是错误的,为什么? int main() { Complex a,b; Complex c=a+b; Complex d=a; Complex e; e=a; return 0; }*/ class Complex{ public: void getRI(float R,float I); //设置复数的两个私有成员 void output(); //输出这个复数 void add(Complex c); //与另一复数的加法函数 原型为 add (Complex c); void isEqual(Complex c); //判断与另一复数是否相等 Complex(){ //不带参数的构造函数 real=0; imaginary=0; } Complex(float R,float I); //以实部和虚部构造 Complex(Complex &c); //复制构造函数 private: float real,imaginary; }; Complex::Complex(float R,float I) //带参数构造函数的实现 { real=R; imaginary=I; } Complex::Complex(Complex &c){ real=c.real; imaginary=c.imaginary; cout<<"calling the copy constructor"<<endl; } void Complex::getRI(float R,float I){ real=R; imaginary=I; } void Complex::output(){ cout<<real<<"+"<<imaginary<<"i"<<endl; } void Complex::add(Complex c){ cout<<"两复数相加为:"; cout<<real+c.real<<"+"<<imaginary+c.imaginary<<"i"<<endl; } void Complex::isEqual(Complex c){ if(real==c.real) { if(imaginary==c.imaginary) cout<<"They are equal."<<endl; } else cout<<"They are not equal."<<endl; } int main(int argc, char** argv) { Complex c1; Complex c2(1,2); //调用带参数的构造函数 Complex c3(3,4); //用对象c2初始化对象c3,复制构造函数被调用 float R1,I1,R2,I2; cin>>R1>>I1; cin>>R2>>I2; c2.getRI(R1,I1); c3.getRI(R2,I2); cout<<"复数c2为:"; c2.output(); cout<<"复数c3为:"; c3.output(); c2.add(c3); c2.isEqual(c3); /*函数调用的时候不用 也不可以包含两类型名, 应该写成myComplex.add(c); */ Complex a,b; Complex c=a+b; Complex d=a; Complex e; e=a; return 0; } ```
文件的读写出现错误,导致文件信息无法写入到程序中
此部分函数如下 ```//提取文件信息函数 void draw() { mess *p; system("cls"); fp=fopen("d:\\stu.txt","rb+"); //<<-- if(fp==NULL) { printf("打开失败,文件不存在。\n"); fclose(fp); system("pause"); system("cls"); return; } fseek(fp,0,SEEK_SET); while(!feof(fp)) { p=(mess*)malloc(sizeof(mess)); fscanf(fp,"%ld %s %s %d %d %s %s %s", &p->number,p->name,p->sex,&p->year,&p->month,p->add, p->phone,p->mail); p->next=head; head=p; } fclose(fp); system("pause"); system("cls"); return; } ```![图片说明](https://img-ask.csdn.net/upload/202003/03/1583227121_433753.png)
为什么会出错?构造函数应该怎么调用?
![图片说明](https://img-ask.csdn.net/upload/202003/25/1585130026_316092.png)![图片说明](https://img-ask.csdn.net/upload/202003/25/1585130043_483666.png)![图片说明](https://img-ask.csdn.net/upload/202003/25/1585130056_158363.png) /*6. 更加完整建立一个复数类 Complex,要求 a. 含两个私有数据成员:real, imaginary: float b. 具有三种构造函数:a.不带参数构造: 0+0i b.以实部和虚部构造 c.拷贝构造函数 c.公有成员函数包括如下功能: 输出这个复数 与另一复数的加法函数,要求函数原型为 complex add(complex c); 判断与另一复数是否相等 要求函数原型为bool isEqual(complex c); 在main函数中,输入两个复数,判断两个复数是否相等(实部和虚部要分别相等),然后两者相加之和赋值给一个新的复数,并输出 ``` #include <iostream> using namespace std; /* run this program using the console pauser or add your own getch, system("pause") or input loop */ 思考:基于上面的Complex类,有如下main函数能否通过运行,有那些是错误的,为什么? int main() { Complex a,b; Complex c=a+b; Complex d=a; Complex e; e=a; return 0; }*/ class Complex{ public: void getRI(float R,float I); //设置复数的两个私有成员 void output(); //输出这个复数 void add(Complex c); //与另一复数的加法函数 原型为 add (Complex c); void isEqual(Complex c); //判断与另一复数是否相等 Complex(){ //不带参数的构造函数 real=0; imaginary=0; } Complex(float R,float I); //以实部和虚部构造 Complex(Complex &c); //复制构造函数 private: float real,imaginary; }; Complex::Complex(float R,float I) //带参数构造函数的实现 { real=R; imaginary=I; } Complex::Comeplex(Complex &c){ real=c.real; imaginary=c.imaginary; cout<<"calling the copy constructor"<<endl; } void Complex::getRI(float R,float I){ real=R; imaginary=I; } void Complex::output(){ cout<<real<<"+"<<imaginary<<"i"<<endl; } void Complex::add(Complex c){ cout<<"两复数相加为:"; cout<<real+c.real<<"+"<<imaginary+c.imaginary<<"i"<<endl; } void Complex::isEqual(Complex c){ if(real==c.real) { if(imaginary==c.imaginary) cout<<"They are equal."<<endl; } else cout<<"They are not equal."<<endl; } int main(int argc, char** argv) { Complex c1; Complex c2(1,2); //调用带参数的构造函数 Complex c3(c2); //用对象c2初始化对象c3,复制构造函数被调用 Complex myComplex,a; //定义两个对象 float R1,I1,R2,I2; cin>>R1>>I1; cin>>R2>>I2; myComplex.getRI(R1,I1); a.getRI(R2,I2); cout<<"复数myComplex为:"; myComplex.output(); cout<<"复数c为:"; a.output(); myComplex.add(a); /*函数调用的时候不用 也不可以包含两类型名, 应该写成myComplex.add(c); */ myComplex.isEqual(a); return 0; } ```
初学Socket,写了一个局域网通信的C程序,虽然可以正常运行,但是出现了一个警告,求解决
一下是服务器代码(只有服务器出错了) #include<stdio.h> #include <stdlib.h> #include <WinSock2.h> #pragma comment (lib,"WS2_32.lib") SOCKADDR_IN cAddr = {0}; int len = sizeof(cAddr); SOCKET clientSocket[1024]; int count = 0; void tongxin(int idx) { char buff[1024]; int r; int i; while(1) { r = recv(clientSocket[idx],buff,1023,0); if(r > 0) { buff[r] = 0; printf("%d:%s\n",idx,buff); for(i = 0; i < count; i++){ send(clientSocket[i],buff,strlen(buff),0); } } } } int main(int argc, char *argv[]) { WSADATA wsaData; WSAStartup(MAKEWORD(2,2),&wsaData); if(LOBYTE(wsaData.wVersion) != 2 || HIBYTE(wsaData.wVersion) != 2) { printf("加载的套接字版本不一致!\n"); system("pause"); return 0; } //创建套接字 SOCKET serveSocket = socket(AF_INET,SOCK_STREAM,0); if(serveSocket == SOCKET_ERROR) { printf("创建socket失败!\n"); WSACleanup(); system("pause"); return 0; } //创建服务器地址族 SOCKADDR_IN addr = {0}; addr.sin_family = AF_INET; addr.sin_addr.S_un.S_addr = inet_addr("192.168.1.5"); addr.sin_port = htons(10086); //绑定 int r = bind(serveSocket,(struct sockaddr*)&addr,sizeof(addr)); if(r == -1) { printf("bind失败!\n"); closesocket(serveSocket); WSACleanup(); system("pause"); } //监听 r = listen(serveSocket,10); if(-1 == r) { printf("监听失败!\n"); closesocket(serveSocket); WSACleanup(); system("pause"); return 0; } //等待客户端连接 while(1) { clientSocket[count] = accept(serveSocket,(struct sockaddr*)&cAddr,&len); if(clientSocket[count] == SOCKET_ERROR) { printf("服务器宕机了!\n"); closesocket(serveSocket); WSACleanup(); system("pause"); return 0; } printf("有客户端连接到了服务器: %s\n",inet_ntoa(cAddr.sin_addr)); CreateThread(NULL,0,(LPTHREAD_START_ROUTINE)tongxin,(char*)count,0,NULL); count++; } return 0; } 警告信息为:D:\dev-c++\dev-c++文档\网络聊天\服务器端\main.c In function 'main': 94 56 D:\dev-c++\dev-c++文档\网络聊天\服务器端\main.c [Warning] cast to pointer from integer of different size [-Wint-to-pointer-cast] 似乎是说CreateThread()第四个参数不对,而客户端由于我写的是NULL,所以没有警告。这个怎么解决?谢谢。
scanf("%s",&a);与scanf("%s",a);的区别是什么? 为什么下面的两个都正确?
第一个 char a[1000]; scanf("%s",&a); printf("%s\n",a); system("pause"); 第二个 char a[1000]; scanf("%s",a); printf("%s\n",a); system("pause"); 为什么上面两个运行结果都正确?
为什么无法调用构造函数?代码应该怎样修改?
![图片说明](https://img-ask.csdn.net/upload/202003/25/1585128168_487032.png) /*5、编写C++程序,实现如下功能: a.定义一个类,Point, 具有x, y轴坐标两个私有数据成员(float类型); b.具有获取和设置x,y值的公有函数;写出两种构造函数;其原型为: Point();//此时初始化x,y为0 Point(float xx,float yy); c.具有计算与另一个类对象p1之间距离的公有函数:float calculate_distance(Point p1); d. 在主函数中,提示输入p1, p2两点的x,y坐标,并计算两点的距离; e.在main函数中测试你所设计的所有成员函数。*/ ``` #include <iostream> #include <math.h> using namespace std; /* run this program using the console pauser or add your own getch, system("pause") or input loop */ class Point{ public: Point(){ x=0; y=0; } //无参数的构造函数 Point(float xx,float yy); //有参数的构造函数 float calculate_distance(Point p1); private: float x,y; }; Point::Point(float xx,float yy){ x=xx; y=yy; cout<<"("<<x<<","<<y<<")"<<endl; } float Point::calculate_distance(Point p1){ return (float)sqrt((x-p1.x)*(x-p1.x)+(y-p1.y)*(y-p1.y)); } int main(int argc, char** argv) { Point p,p1; //定义对象p、p1 float x,y; //对象p的私有数据成员 float x1,y1; //对象p1的私有对象成员 float d1=0,d2=0; cin>>x>>y; cin>>x1>>y1; Point p; //调用无参数的构造函数 Point p(x,y); //调用有参数的构造函数 p1.Point(x1,y1); d1=p.calculate_distance(p1); d2=p1.calculate_distance(p); cout<<"两点间距离为"<<d1<<endl; cout<<"两点间距离为"<<d2<<endl; return 0; } ```
C++类中要怎样调用字符串?为什么输出是这样的结果?
/*定义一个Dog类,包含age,weight等属性,以及对这些属性操作的方法 实现并测试这个类*/ ``` #include <iostream> #include <string.h> #define N 10 using namespace std; /* run this program using the console pauser or add your own getch, system("pause") or input loop */ class Dog{ public: void Age(int a); void Weight(int b); void Haircolor(char s[N]); private: int x,y; char c[N]; }; void Dog::Age(int a){ x=a; cout<<"age="<<x<<endl; } void Dog::Weight(int b){ y=b; cout<<"weight="<<y<<endl; } void Dog::Haircolor(char s[N]){ int i=0,n=0; strcat(c,s); n=strlen(c); cout<<"Haircolor="; while((i++)<n){ cout<<c[i]; } } int main(int argc, char** argv) { Dog mydog; //定义对象mydog int x=0,y=0; char c[N]; cin>>x>>y; cin>>c[N]; mydog.Age(x); mydog.Weight(y); mydog.Haircolor(c); return 0; } ```![图片说明](https://img-ask.csdn.net/upload/202003/20/1584669498_184479.png)
请问大佬们,C++出现函数嵌套问题怎么处理
要求做一个计算ax^2+bx+c=0的程序,程序做出来可以运行,但是我设计的报错环节总有问题,报完错下面的过程仍会照常输出,我希望它报完错就停止运行。老师给我的解释是出现了函数嵌套的问题,但是初学我看不出问题,请 大佬指教。 #include<iostream> #include<cmath> using namespace std; void caluate(); int main(){ double a,b,c; cout<<"calcuate ax^2+bx+c=0"<<endl; /*菜单语句*/ cout<<"please enter the number of 'a' is :"<<endl;cin>>a; cout<<"the number of 'b' is"<<endl;cin>>b; cout<<"the number of 'c' is"<<endl;cin>>c; double x,y,z,h,l,m; m=b*b-4*a*c; if(m<0) cout<<"This question unanswered !"<<endl; else void calcuate(); void calcuate(); { x=sqrt(m); /*计算更号下b^2-4ac*/ y=(-b+x); z=(-b-x); /*计算步骤*/ h=y/2*a; l=z/2*a; cout<<"The result is:"<<endl; cout<<"X1= "<<h<<endl; cout<<"X2= "<<l<<endl; } system("pause"); return 0; }
新人学习C语言,调试遇到错误,请前辈们帮忙看看哪里出错了
学习C的函数部分,自己敲了断代码一直提示出错。 代码部分: ``` # include <stdio.h> # include <stdlib.h> bool Prime ( int m ) { int n; for ( n = 2; n <= m; ++n ) { if ( m % n == 0 ) break; } if( n == m ) return true; else return false; } int main (void) { int val; int i; printf("请你随意输入一个数字,我会判断出1~该数字之间的所有素数"); scanf("%d",&val); for( i = 2; i <= val; ++i ) { if( Prime(i) ) printf("%d\n",i); } system ("pause"); return 0; } ``` 出错内容: 1. error 2 error C2059: syntax error : ';' 2.error C2059: syntax error : 'type' 3.error C2061: syntax error : identifier 'Prime' 我用的是win10+Microsoft Visual C++ 2010 Express 当我把bool Prime()函数改为int Prime () 函数的判断 return 1;问题就消失了。 求教为什么不能用bool型作为函数。
萌新请问,for算式结果为什么和预想不一致
目的是计算 12+22+...+nx<=1000时 n的最大值,但是这样算法下去,会比正确值多2,请问是哪里出问题了呢? #include<iostream> using namespace std; int main() { int n,b,c=0; for(n=1;c<=1000;n++) { b=n*10+2; c+=b; } cout<<n<<endl; system("pause"); return 0; }
为什么运行结果id的值不对?
#include<stdio.h> #include<stdlib.h> struct book { char title[50]; char author[50]; char subject[100]; int id[50]; }book={"cyuyan","bb","biancheng",12}; main() { printf("%s%s%s%d",book.title,book.author,book.subject,book.id); system("pause"); return 0; }
求大神看看我真的不知道哪里错了
``` #include <string.h> //输入 typedef struct DataType { char name[10]; char num[12]; }Datatype; Datatype InputInfo() { Datatype x; printf("请输入姓名和电话号码:\n"); scanf("%s%s",&x.name,&x.num); return x; } //输出 void PrintInfo(Datatype x) { printf("姓名:%s,电话号码:%s\n",x.name,x.num); } //比较姓名函数 int CompareName(Datatype a, Datatype b) { if (strcmp(a.name, b.name) == 0) return 1; else return 0; } ``` ``` typedef struct Node { Datatype data; struct Node* next; }Node, *LinkList; //创建带头节点的链表 void InitList(LinkList *head) { LinkList p = (LinkList)malloc(sizeof(Node)); p->next = NULL; (*head) = p; } //查询链表长度 int LengthList(LinkList head) { LinkList p = head; int length = 0; while (p->next != NULL) { length++; p = p->next; } return length; } //按内容查找元素位置,成功返回位置,失败返回0 int LocateElem(LinkList head, Datatype e, int(*fun)(Datatype, Datatype)) { int pos = 0; LinkList p = head->next; while (p != NULL) { if ((*fun)(p->data, e) == 1) return (pos + 1); p = p->next; pos++; } return 0; } //按位置返回元素,成返回1,失败返回0 int GetElem(LinkList head, int pos, Datatype *e) { int length = LengthList(head); LinkList p = head; if (pos < 1 || pos > length) return 0; for (int i = 0; i < pos; i++) { p = p->next; } (*e) = p->data; return 1; } //按位置删除元素,成功返回1,失败返回0 int DeleteElem(LinkList head, int pos, Datatype *e) { int length = LengthList(head); if (pos < 1 || pos > length) return 0; LinkList p = head; LinkList q = NULL; for (int i = 0; i < pos - 1; i++) { p = p->next; } q = p->next; p->next = p->next->next; (*e) = q->data; free(q); return 1; } //按位置插入元素,成功返回1,失败返回0 int InsertElem(LinkList head, int pos, Datatype e) { int length = LengthList(head); if (pos < 1 || pos > length + 1) return 0; LinkList p = head; LinkList pNew = (LinkList)malloc(sizeof(Datatype)); pNew->data = e; for (int i = 0; i < pos - 1; i++) { p = p->next; } pNew->next = p->next; p->next = pNew; return 1; } //遍历链表 void TraverseList(LinkList head) { int length = LengthList(head); LinkList p = head->next; for (int i = 0; i < length; i++) { PrintInfo(p->data); p = p->next; } } //销毁链表 void DestroyList(LinkList head) { LinkList p = head; LinkList q = p; while (p != NULL) { p = p->next; free(q); q = p; } } ``` ``` #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <stdlib.h> #include "DataType.h" #include "LinkList.h" int main() { int ch,pos,length;//用于输入操作数,返回位置,链表长度 Datatype x;//用来输入元素 LinkList L; InitList(&L); while (1) { system("cls"); printf("请输入要进行的操作\n"); printf("1.添加链表元素\n"); printf("2.插入链表元素\n"); printf("3.删除链表元素\n"); printf("4.修改链表元素\n"); printf("5.打印链表元素\n"); printf("6.销毁退出\n"); scanf("%d",&ch); switch (ch) { case 1: x = InputInfo(); length = LengthList(L); if (InsertElem(L, length + 1, x)) printf("添加成功\n"); else printf("添加失败\n"); system("pause"); break; case 2: x = InputInfo(); printf("请输入你要插入的位置\n"); scanf("%d",&pos); if (InsertElem(L, pos, x)) printf("插入成功\n"); else printf("插入失败\n"); system("pause"); break; case 3: printf("请输入你要删除的名字\n"); scanf("%s",&x.name); pos = LocateElem(L, x, CompareName); if (DeleteElem(L, pos, &x)) { printf("删除成功\n"); PrintInfo(x); } else printf("删除失败\n"); system("pause"); break; case 4: printf("请输入被修改的名字:\n"); scanf("%s",&x.name); pos = LocateElem(L, x, CompareName); if (DeleteElem(L, pos, &x)) { printf("信息修改为\n"); x = InputInfo(); InsertElem(L, pos, x); printf("修改成功\n"); } else printf("修改失败\n"); system("pause"); break; case 5: TraverseList(L); system("pause"); break; case 6: DestroyList(L); return; } } system("pause"); return 0; } ``` ![图片说明](https://img-ask.csdn.net/upload/202002/19/1582109924_642226.png) 求大神看看为什么我的删除函数会报错啊
各位大佬们,本人智商捉鸡,一个CUDA并行规约的问题想了好几天了绕不过来,求指导!!!
**这是我在网上找的一个CUDA求最值的核函数,把它调通了之后可以正常获取到最大值。 现在就是一个5000行1024列的一个矩阵,通过cuda并行规约可以计算输出每一行的最值,最后文件保存输出的是5000个最值,每一行数据的最值。 但是我想要的是每一个最值所对应的索引值,即矩阵下标值,我尝试了很多方法都不行,因为并行规约的问题,下标值一直变,没办法得到最初的行序列中的最大值对应的索引值。 但现在我想获取到每一个最值对应的索引值,但就是怎么该都获取不到,各位大佬可不可以给点想法,该怎么改啊, 对于我来说,只有最大值对应的真实索引下标值才是真正有用的数据。 下面的代码可以直接复制运行。** ``` #include<math.h> #include<cuda_runtime_api.h> #include "device_launch_parameters.h" #include<stdio.h> #include<stdlib.h> #include<time.h> #include <cuComplex.h> #include <device_functions.h> #include <cuda_runtime.h> //#include <cufft.h> #define Height 5000 #define Width 1024 const int N = Height * Width; const int threadsPerBlock = 1024; const int blocksPerGrid = (N + threadsPerBlock - 1) / threadsPerBlock; #define SAVE_FILE_PATH "F:\\GPU-Reduce-partialMax_device_Result.txt" __global__ void findMaxOfMatrix(double Mat_device[Height][Width], double partialMax_device[Height]) { //申请共享内存,存在于每个block中(GTX1060的共享内存为48KB) __shared__ double partialMax[threadsPerBlock]; //确定索引 int id = threadIdx.x + blockIdx.x * blockDim.x; int tid = threadIdx.x; //double MaxValue[threadsPerBlock]; //int index; //传global memory数据到shared memory partialMax[tid] = Mat_device[id / Width][id % Width]; //传输同步 __syncthreads(); //在共享存储器中进行规约 for (int stride = blockDim.x / 2; stride > 0; stride >>= 1)//右移一位相当于除了个2 { __syncthreads(); if (tid < stride) { if (partialMax[tid] < partialMax[tid + stride]) { int temp = partialMax[tid]; partialMax[tid] = partialMax[tid + stride]; partialMax[tid + stride] = temp; } __syncthreads(); } } //将当前block的计算结果写回输出数组 if (tid == 0) { //partialMax_device[blockIdx.x] = index; partialMax_device[blockIdx.x] = partialMax[0]; } } int main() { float time1; cudaEvent_t start1, stop1; cudaEventCreate(&start1); cudaEventCreate(&stop1); //申请host端内存及初始化,获得随机值 double(*Mat_host)[Width] = new double[Height][Width]; double *partialMax_host = new double[blocksPerGrid]; //构建一个 Height 行 Width 列的数组矩阵 for (int i = 0; i < Height; ++i) for (int j = 0; j < Width; j++) Mat_host[i][j] = (rand() % 2020) + 1; //分配Device空间矩阵 double(*Mat_device)[Width]; double *partialMax_device; cudaMalloc((void**)&Mat_device, N * sizeof(double)); cudaMalloc((void**)&partialMax_device, blocksPerGrid*sizeof(double)); //int *index; //cudaMalloc((void**)&index, blocksPerGrid * sizeof(double)); //int window_slide_num = blocksPerGrid; cudaEventRecord(start1, 0); //把数据从Host传到Device cudaMemcpy(Mat_device, Mat_host, N * sizeof(double), cudaMemcpyHostToDevice); //调用内核函数 findMaxOfMatrix << <blocksPerGrid, threadsPerBlock >> >(Mat_device, partialMax_device); //将结果传回到主机端 cudaMemcpy(partialMax_host, partialMax_device, sizeof(double)*blocksPerGrid, cudaMemcpyDeviceToHost); //将部分和继续作对比,求最大值 /*double max = 0.0; for (int i = 0; i < blocksPerGrid; i++) { if (max < partialMax_host[i]) { max = partialMax_host[i]; } }*/ cudaEventRecord(stop1, 0); cudaEventSynchronize(stop1); //printf("\n\n maxNum:%5.5lf ", max); cudaEventElapsedTime(&time1, start1, stop1); printf("\n The time of calculating is : %f ms\n", time1); //创建一个用于读写的空文件,如果文件名称与已存在的文件相同,则会删除已有文件的内容,文件被视为一个新的空文件 FILE* fp; char file[128] = { 0 }; sprintf(file, SAVE_FILE_PATH); fp = fopen(file, "w+"); if (fp == NULL){ printf("保存数据的文件创建失败!\n"); return 0; } else { printf("\n正在保存数据,请稍等.....\n"); } for (int i = 0; i < blocksPerGrid; i++) { fprintf(fp, "%5.5lf\n", partialMax_host[i]);//将数据格式化写入stream文件流中 } fclose(fp); printf("\n文件保存完成!\n\n"); double max = 0.0; for (int i = 0; i < blocksPerGrid; i++) { if (max < partialMax_host[i]) { max = partialMax_host[i]; } } printf("\n\n maxNum:%5.5lf ", max); //释放显空间 system("pause"); cudaFree(Mat_device); cudaFree(partialMax_device); free(Mat_host); free(partialMax_host); return 0; } ```
PTA 1001 A+B Format (20分)这题为什么我是编译错误
题目是: ![图片说明](https://img-ask.csdn.net/upload/202003/16/1584323852_91265.png) 我的答案: ``` #include <stdio.h> #include <stdlib.h> /* run this program using the console pauser or add your own getch, system("pause") or input loop */ int main(int argc, char *argv[]) { int a,b; scanf("%d%d",&a,&b); int sum; sum=a+b; if(sum<0){ printf("-"); sum=-sum; } //解决负号问题,现在sum一定是正数 char s[8]; _itoa(sum,s,10); int w=strlen(s); int d=w%3; int i=0; for(i=0;i<w;i++){ if((i-d)%3==0&&i!=0){ printf(","); } printf("%c",s[i]); } return 0; } ``` 但是结果是编译错误 这啥原因呢??
为什么 我这代码运行时没输入完就结束?“未完成”????急求!!!!
``` #include<stdio.h> #include<stdlib.h> #include<string.h> typedef struct stu { char name[10]; char guan[10]; char number1[20]; char number2[20]; char box[30]; }gs; typedef struct pgs { gs chat; pgs* next; }*ptgs; ptgs head=(ptgs)malloc(sizeof(pgs)); int denglu(); int fun1(); int fun2(); int fun3(); int fun4(); int app(char *p);//计算字符串长度! int main() { int i,a; head->next=NULL; printf("\n\n\t\t\t\t**************************************************************\n"); printf("\t\t\t\t\t\t\t通讯录管理系统\n"); printf("\t\t\t\t\t\t\t\t设计者:\n"); printf("\t\t\t\t**************************************************************\n"); printf("\t\t\t\t欢迎使用通讯录管理系统!!!!!!\n"); printf("\t\t\t\t继续请按 1 ,退出请按 0 !\n"); printf("\t\t\t\t请输入:"); for(i=0;i<2;i=1) { scanf("%d",&a); getchar(); switch(a) { case 1:denglu();break; case 0:break; default:printf("\t\t\t\t请重新输入:");continue; } break; } printf("\t\t\t\t系统即将退出!!!"); printf("\t\t\t\t谢谢使用!!!!!"); } int denglu() { int a,i,j,k; printf("\n\n"); printf("\t\t\t\t**************************************************************\n"); printf("\t\t\t\t\t\t\t>登陆界面<\n"); printf("\n\t\t\t\t\t\t\t登录请输入 1 !\n"); printf("\t\t\t\t\t\t\t注册请输入 2 !\n"); printf("\t\t\t\t\t\t\t退出请输入 0 !\n"); printf("\t\t\t\t请输入:"); for(i=0;i<2;i=1) { scanf("%d",&a); getchar(); switch(a) { case 1:fun1();break; case 2:fun2();break; case 0:break; default:printf("\t\t\t\t请重新输入:");continue; } break; } } int fun1()//登陆函数 { FILE *fp; int i,k; char e[81],f[81],a[81],b[81]; if((fp = fopen("D:\\w\\hao\\mm.txt","r"))==0) { printf("\t\t\t\t文件打开失败!!!!"); denglu(); } printf("\n\n\t\t\t\t**************************************************************"); printf("\n\t\t\t\t\t\t\t<>登陆<>\n"); printf("\n\t\t\t\t用户名:"); scanf("%s",e); printf("\n\t\t\t\t密码:"); scanf("%s",f); fscanf(fp,"%s %s",a,b); fclose(fp); if(strcmp(a,e)==0&&strcmp(b,f)==0) { printf("\n\t\t\t\t登陆成功!!!\n"); fun3(); } else { printf("\n\t\t\t\t用户名或密码错误!!\n"); printf("\t\t\t\t重新登陆请按 1 ,退出登陆请按 0 !\n"); printf("\t\t\t\t请选择:") ; for(i=1;i<2;i=1) { scanf("%d",&k); getchar(); switch(k) { case 1: fun1();break; case 0: denglu();break; default: printf("\t\t\t\t\t\t输入错误,请重新输入:"); continue; } break; } } system("pause"); } int fun2()//注册函数 { FILE *fp; int i,k; fp = fopen("D:\\w\\hao\\mm.txt","w"); char a[81],b[81],c[81]; printf("\n\n\t\t\t\t**************************************************************\n"); printf("\t\t\t\t\t\t\t<>注册界面<>\n"); printf("\n\t\t\t\t请输入用户名:"); scanf("%s",a); printf("\n\t\t\t\t请输入密码:"); scanf("%s",b); printf("\n\t\t\t\t请再次输入密码:"); scanf("%s",c); fputs(a,fp); fputs("\n",fp); fputs(b,fp); fclose(fp); if(strcmp(b,c)==0) { printf("\n\t\t\t\t注册成功!\n"); fun1(); } else { printf("\t\t\t\t输入的两次密码不一样,注册失败!\n"); printf("\t\t\t\t重新注册请输入 1 ,退出注册请输入 0 !"); for(i=1;i<2;i=1) { scanf("%d",&k); getchar(); switch(k) { case 1: fun2();break; case 0: denglu();break; default: printf("\t\t\t\t\t\t输入错误,请重新输入:"); continue; } break; } } system("pause"); } int fun3()//菜单 { int j; char k; printf("\n\n\t\t\t\t**************************************************************\n"); printf("\t\t\t\t\t\t\t<>功能中心<>\n"); printf("\n\t\t\t\t\t\t「\n"); printf("\t\t\t\t\t\t\t1.信息录入 \n"); printf("\t\t\t\t\t\t\t2.信息浏览 \n"); printf("\t\t\t\t\t\t\t3.信息查询 \n"); printf("\t\t\t\t\t\t\t4.信息修改 \n"); printf("\t\t\t\t\t\t\t5.退出系统 \n"); printf("\t\t\t\t\t\t\t 」\n"); printf("\t\t\t\t请输入相应数字:"); for(j=0;j<2;j=1) { scanf("%s",&k); getchar(); switch(k) { case '1':fun4();break; case '2': case '3': case '4': case '5':printf("\t\t\t\t系统即将退出!!!\n");break; default:printf("\t\t\t\t输入错误!!\n请重新输入:");continue; } } system("pause"); } int fun4()//添加联系人! { int t,n,a; char f='y'; ptgs p=head,q; FILE *V; if((V=fopen("D://information.dat","a+"))==NULL) { printf("\t\t\t\t文件无法打开!!!\n"); system("pause"); fun3(); } fprintf(V,"\n\t\t\t\t***************************通讯录列表******************************\n"); while(p->next)p=p->next;//修改上一个指针域,使其指向现在的节点! while(f!='n'&&f!='N') { q=(ptgs)malloc(sizeof(pgs));//malloc内存分配函数;内存大小为sizeof(pgs ). p->next=q; p=q; q->next=q; printf("\t\t\t\t姓名:"); scanf("%s",q->chat.name); printf("\n\t\t\t\t贯籍:"); scanf("%s",q->chat.guan); printf("\n\t\t\t\t电话号码1:"); scanf("%s",q->chat.number1); do { n=0; if(app(q->chat.number1)!=11)//判断号码是否为十一位电话号码 { n=1; printf("\t\t\t\t您输入的号码格式不正确!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",q->chat.number1); } else { for(t=0;t<11;t++) { if(q->chat.number1[t]<'0'||q->chat.number1[t]>'9')//判断号码是否都为0-9之间的字符 { n=1; printf("\t\t\t\t您输入的号码格式不正确!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",q->chat.number1); break; } } } }while(n); printf("\n\t\t\t\t电话号码2:"); scanf("%s",q->chat.number2); do { n=0; if(app(q->chat.number2)!=11) { n=1; printf("\t\t\t\t您输入的号码格式不正确!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",q->chat.number2); } else { for(t=0;t<11;t++) { if(q->chat.number2[t]<'0'||q->chat.number2[t]>'9') { n=1; printf("\t\t\t\t您输入的号码格式不正确!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",q->chat.number2); break; } } } }while(n); printf("\n\t\t\t\t邮箱:"); scanf("%s",p->chat.box); do { a=0; for(t=0;p->chat.box[t]='\0';t++) { if(p->chat.box[t]=='@') a++; } if(a!=1); { printf("\n\t\t\t\t输入的邮箱格式不合理!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",p->chat.box); } }while(a!=1); fprintf(V,"\t\t\t%s\t%s\t%s\t%s\t%s",p->chat.name,p->chat.guan,p->chat.number1,p->chat.number2,p->chat.box); p=p->next; printf("\n\t\t\t\t是否继续录入?(Y/N)!\n"); scanf("\t\t\t\t%c",&f); } fclose(V); system("pause"); fun3(); } int app(char *p) { int count,k; k=0; while((p[k] = getchar()) != '\n') { k++; } p='\0'; count=0; for(k=0;p[k]!='\0';k++) { count++; } return count; } ```
有没有大神帮我看看哪里出错了?没输完信息,就自动结束的?未完成?
``` #include<stdio.h> #include<stdlib.h> #include<string.h> typedef struct stu { char name[10]; char guan[10]; char number1[20]; char number2[20]; char box[30]; }gs; typedef struct pgs { gs chat; pgs* next; }*ptgs; ptgs head=(ptgs)malloc(sizeof(pgs)); int denglu(); int fun1(); int fun2(); int fun3(); int fun4(); int app(char *p);//计算字符串长度! int main() { int i,a; head->next=NULL; printf("\n\n\t\t\t\t**************************************************************\n"); printf("\t\t\t\t\t\t\t通讯录管理系统\n"); printf("\t\t\t\t\t\t\t\t设计者:\n"); printf("\t\t\t\t**************************************************************\n"); printf("\t\t\t\t欢迎使用通讯录管理系统!!!!!!\n"); printf("\t\t\t\t继续请按 1 ,退出请按 0 !\n"); printf("\t\t\t\t请输入:"); for(i=0;i<2;i=1) { scanf("%d",&a); getchar(); switch(a) { case 1:denglu();break; case 0:break; default:printf("\t\t\t\t请重新输入:");continue; } break; } printf("\t\t\t\t系统即将退出!!!"); printf("\t\t\t\t谢谢使用!!!!!"); } int denglu() { int a,i,j,k; printf("\n\n"); printf("\t\t\t\t**************************************************************\n"); printf("\t\t\t\t\t\t\t>登陆界面<\n"); printf("\n\t\t\t\t\t\t\t登录请输入 1 !\n"); printf("\t\t\t\t\t\t\t注册请输入 2 !\n"); printf("\t\t\t\t\t\t\t退出请输入 0 !\n"); printf("\t\t\t\t请输入:"); for(i=0;i<2;i=1) { scanf("%d",&a); getchar(); switch(a) { case 1:fun1();break; case 2:fun2();break; case 0:break; default:printf("\t\t\t\t请重新输入:");continue; } break; } } int fun1()//登陆函数 { FILE *fp; int i,k; char e[81],f[81],a[81],b[81]; if((fp = fopen("D:\\w\\hao\\mm.txt","r"))==0) { printf("\t\t\t\t文件打开失败!!!!"); denglu(); } printf("\n\n\t\t\t\t**************************************************************"); printf("\n\t\t\t\t\t\t\t<>登陆<>\n"); printf("\n\t\t\t\t用户名:"); scanf("%s",e); printf("\n\t\t\t\t密码:"); scanf("%s",f); fscanf(fp,"%s %s",a,b); fclose(fp); if(strcmp(a,e)==0&&strcmp(b,f)==0) { printf("\n\t\t\t\t登陆成功!!!\n"); fun3(); } else { printf("\n\t\t\t\t用户名或密码错误!!\n"); printf("\t\t\t\t重新登陆请按 1 ,退出登陆请按 0 !\n"); printf("\t\t\t\t请选择:") ; for(i=1;i<2;i=1) { scanf("%d",&k); getchar(); switch(k) { case 1: fun1();break; case 0: denglu();break; default: printf("\t\t\t\t\t\t输入错误,请重新输入:"); continue; } break; } } system("pause"); } int fun2()//注册函数 { FILE *fp; int i,k; fp = fopen("D:\\w\\hao\\mm.txt","w"); char a[81],b[81],c[81]; printf("\n\n\t\t\t\t**************************************************************\n"); printf("\t\t\t\t\t\t\t<>注册界面<>\n"); printf("\n\t\t\t\t请输入用户名:"); scanf("%s",a); printf("\n\t\t\t\t请输入密码:"); scanf("%s",b); printf("\n\t\t\t\t请再次输入密码:"); scanf("%s",c); fputs(a,fp); fputs("\n",fp); fputs(b,fp); fclose(fp); if(strcmp(b,c)==0) { printf("\n\t\t\t\t注册成功!\n"); fun1(); } else { printf("\t\t\t\t输入的两次密码不一样,注册失败!\n"); printf("\t\t\t\t重新注册请输入 1 ,退出注册请输入 0 !"); for(i=1;i<2;i=1) { scanf("%d",&k); getchar(); switch(k) { case 1: fun2();break; case 0: denglu();break; default: printf("\t\t\t\t\t\t输入错误,请重新输入:"); continue; } break; } } system("pause"); } int fun3()//菜单 { int j; char k; printf("\n\n\t\t\t\t**************************************************************\n"); printf("\t\t\t\t\t\t\t<>功能中心<>\n"); printf("\n\t\t\t\t\t\t「\n"); printf("\t\t\t\t\t\t\t1.信息录入 \n"); printf("\t\t\t\t\t\t\t2.信息浏览 \n"); printf("\t\t\t\t\t\t\t3.信息查询 \n"); printf("\t\t\t\t\t\t\t4.信息修改 \n"); printf("\t\t\t\t\t\t\t5.退出系统 \n"); printf("\t\t\t\t\t\t\t 」\n"); printf("\t\t\t\t请输入相应数字:"); for(j=0;j<2;j=1) { scanf("%s",&k); getchar(); switch(k) { case '1':fun4();break; case '2': case '3': case '4': case '5':printf("\t\t\t\t系统即将退出!!!\n");break; default:printf("\t\t\t\t输入错误!!\n请重新输入:");continue; } } system("pause"); } int fun4()//添加联系人! { int t,n,a; char f='y'; ptgs p=head,q; FILE *V; if((V=fopen("D://information.dat","a+"))==NULL) { printf("\t\t\t\t文件无法打开!!!\n"); system("pause"); fun3(); } fprintf(V,"\n\t\t\t\t***************************通讯录列表******************************\n"); while(p->next)p=p->next;//修改上一个指针域,使其指向现在的节点! while(f!='n'&&f!='N') { q=(ptgs)malloc(sizeof(pgs));//malloc内存分配函数;内存大小为sizeof(pgs ). p->next=q; p=q; q->next=q; printf("\t\t\t\t姓名:"); scanf("%s",q->chat.name); printf("\n\t\t\t\t贯籍:"); scanf("%s",q->chat.guan); printf("\n\t\t\t\t电话号码1:"); scanf("%s",q->chat.number1); do { n=0; if(app(q->chat.number1)!=11)//判断号码是否为十一位电话号码 { n=1; printf("\t\t\t\t您输入的号码格式不正确!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",q->chat.number1); } else { for(t=0;t<11;t++) { if(q->chat.number1[t]<'0'||q->chat.number1[t]>'9')//判断号码是否都为0-9之间的字符 { n=1; printf("\t\t\t\t您输入的号码格式不正确!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",q->chat.number1); break; } } } }while(n); printf("\n\t\t\t\t电话号码2:"); scanf("%s",q->chat.number2); do { n=0; if(app(q->chat.number2)!=11) { n=1; printf("\t\t\t\t您输入的号码格式不正确!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",q->chat.number2); } else { for(t=0;t<11;t++) { if(q->chat.number2[t]<'0'||q->chat.number2[t]>'9') { n=1; printf("\t\t\t\t您输入的号码格式不正确!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",q->chat.number2); break; } } } }while(n); printf("\n\t\t\t\t邮箱:"); scanf("%s",p->chat.box); do { a=0; for(t=0;p->chat.box[t]='\0';t++) { if(p->chat.box[t]=='@') a++; } if(a!=1); { printf("\n\t\t\t\t输入的邮箱格式不合理!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",p->chat.box); } }while(a!=1); fprintf(V,"\t\t\t%s\t%s\t%s\t%s\t%s",p->chat.name,p->chat.guan,p->chat.number1,p->chat.number2,p->chat.box); p=p->next; printf("\n\t\t\t\t是否继续录入?(Y/N)!\n"); scanf("\t\t\t\t%c",&f); } fclose(V); system("pause"); fun3(); } int app(char *p) { int count,k; k=0; while((p[k] = getchar()) != '\n') { k++; } p='\0'; count=0; for(k=0;p[k]!='\0';k++) { count++; } return count; } ```
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
JSON解析——net.sf.json.JSONObject
简介 在程序开发过程中,在参数传递,函数返回值等方面,越来越多的使用JSON。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,同时也易于机器解析和生成、易于理解、阅读和撰写,而且Json采用完全独立于语言的文本格式,这使得Json成为理想的数据交换语言。 JSON建构于两种结构: “名称/值”对的集合(A Collection of name/va...
卸载 x 雷某度!GitHub 标星 1.5w+,从此我只用这款全能高速下载工具!
作者 | Rocky0429 来源 | Python空间 大家好,我是 Rocky0429,一个喜欢在网上收集各种资源的蒟蒻… 网上资源眼花缭乱,下载的方式也同样千奇百怪,比如 BT 下载,磁力链接,网盘资源等等等等,下个资源可真不容易,不一样的方式要用不同的下载软件,因此某比较有名的 x 雷和某度网盘成了我经常使用的工具。 作为一个没有钱的穷鬼,某度网盘几十 kb 的下载速度让我...
2019年还剩1天,我从外包公司离职了
这日子过的可真快啊,2019年还剩1天,外包公司干了不到3个月,我离职了
我一个37岁的程序员朋友
周末了,人一旦没有点事情干,心里就瞎想,而且跟几个老男人坐在一起,更容易瞎想,我自己现在也是 30 岁了,也是无时无刻在担心自己的职业生涯,担心丢掉工作没有收入,担心身体机能下降,担心突...
计算机网络的核心概念
这是《计算机网络》系列文章的第二篇文章 我们第一篇文章讲述了计算机网络的基本概念,互联网的基本名词,什么是协议以及几种接入网以及网络传输的物理媒体,那么本篇文章我们来探讨一下网络核心、交换网络、时延、丢包、吞吐量以及计算机网络的协议层次和网络攻击。 网络核心 网络的核心是由因特网端系统和链路构成的网状网络,下面这幅图正确的表达了这一点 那么在不同的 ISP 和本地以及家庭网络是如何交换信息的呢?...
python自动下载图片
近日闲来无事,总有一种无形的力量萦绕在朕身边,让朕精神涣散,昏昏欲睡。 可是,像朕这么有职业操守的社畜怎么能在上班期间睡瞌睡呢,我不禁陷入了沉思。。。。 突然旁边的IOS同事问:‘嘿,兄弟,我发现一个网站的图片很有意思啊,能不能帮我保存下来提升我的开发灵感?’ 作为一个坚强的社畜怎么能说自己不行呢,当时朕就不假思索的答应:‘oh, It’s simple. Wait for me for a ...
一名大专同学的四个问题
【前言】   收到一封来信,赶上各种事情拖了几日,利用今天要放下工作的时机,做个回复。   2020年到了,就以这一封信,作为开年标志吧。 【正文】   您好,我是一名现在有很多困惑的大二学生。有一些问题想要向您请教。   先说一下我的基本情况,高考失利,不想复读,来到广州一所大专读计算机应用技术专业。学校是偏艺术类的,计算机专业没有实验室更不用说工作室了。而且学校的学风也不好。但我很想在计算机领...
复习一周,京东+百度一面,不小心都拿了Offer
京东和百度一面都问了啥,面试官百般刁难,可惜我全会。
Java 14 都快来了,为什么还有这么多人固守Java 8?
从Java 9开始,Java版本的发布就让人眼花缭乱了。每隔6个月,都会冒出一个新版本出来,Java 10 , Java 11, Java 12, Java 13, 到2020年3月份,...
达摩院十大科技趋势发布:2020 非同小可!
【CSDN编者按】1月2日,阿里巴巴发布《达摩院2020十大科技趋势》,十大科技趋势分别是:人工智能从感知智能向认知智能演进;计算存储一体化突破AI算力瓶颈;工业互联网的超融合;机器间大规模协作成为可能;模块化降低芯片设计门槛;规模化生产级区块链应用将走入大众;量子计算进入攻坚期;新材料推动半导体器件革新;保护数据隐私的AI技术将加速落地;云成为IT技术创新的中心 。 新的画卷,正在徐徐展开。...
轻松搭建基于 SpringBoot + Vue 的 Web 商城应用
首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行用户代码,而用户只需根据实际代码运行所消耗的资源进行付费。Fun: Fun 是一个用于支持 Serverless 应用部署的工具,能帮助您便捷地管理函数计算、API ...
讲真,这两个IDE插件,可以让你写出质量杠杠的代码
周末躺在床上看《拯救大兵瑞恩》 周末在闲逛的时候,发现了两个优秀的 IDE 插件,据说可以提高代码的质量,我就安装了一下,试了试以后发现,确实很不错,就推荐给大家。 01、Alibaba Java 代码规范插件 《阿里巴巴 Java 开发手册》,相信大家都不会感到陌生,其 IDEA 插件的下载次数据说达到了 80 万次,我今天又贡献了一次。嘿嘿。 该项目的插件地址: https://github....
Python+OpenCV实时图像处理
目录 1、导入库文件 2、设计GUI 3、调用摄像头 4、实时图像处理 4.1、阈值二值化 4.2、边缘检测 4.3、轮廓检测 4.4、高斯滤波 4.5、色彩转换 4.6、调节对比度 5、退出系统 初学OpenCV图像处理的小伙伴肯定对什么高斯函数、滤波处理、阈值二值化等特性非常头疼,这里给各位分享一个小项目,可通过摄像头实时动态查看各类图像处理的特点,也可对各位调参、测试...
2020年一线城市程序员工资大调查
人才需求 一线城市共发布岗位38115个,招聘120827人。 其中 beijing 22805 guangzhou 25081 shanghai 39614 shenzhen 33327 工资分布 2020年中国一线城市程序员的平均工资为16285元,工资中位数为14583元,其中95%的人的工资位于5000到20000元之间。 和往年数据比较: yea...
为什么猝死的都是程序员,基本上不见产品经理猝死呢?
相信大家时不时听到程序员猝死的消息,但是基本上听不到产品经理猝死的消息,这是为什么呢? 我们先百度搜一下:程序员猝死,出现将近700多万条搜索结果: 搜索一下:产品经理猝死,只有400万条的搜索结果,从搜索结果数量上来看,程序员猝死的搜索结果就比产品经理猝死的搜索结果高了一倍,而且从下图可以看到,首页里面的五条搜索结果,其实只有两条才是符合条件。 所以程序员猝死的概率真的比产品经理大,并不是错...
害怕面试被问HashMap?这一篇就搞定了!
声明:本文以jdk1.8为主! 搞定HashMap 作为一个Java从业者,面试的时候肯定会被问到过HashMap,因为对于HashMap来说,可以说是Java集合中的精髓了,如果你觉得自己对它掌握的还不够好,我想今天这篇文章会非常适合你,至少,看了今天这篇文章,以后不怕面试被问HashMap了 其实在我学习HashMap的过程中,我个人觉得HashMap还是挺复杂的,如果真的想把它搞得明明白...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
程序员如何通过造轮子走向人生巅峰?
前言:你所做的事情,也许暂时看不到成果。但不要灰心,你不是没有成长,而是在扎根。 程序员圈经常流行的一句话:“不要重复造轮子”。在计算机领域,我们将封装好的组件、库,叫做轮子。因为它可以拿来直接用,直接塞进我们的项目中,就能实现对应的功能。 有些同学会问,人家都已经做好了,你再来重新弄一遍,有什么意义?这不是在浪费时间吗。 殊不知,造轮子是一种学习方式,能快速进步,造得好,是自己超强能力的表...
推荐10个堪称神器的学习网站
每天都会收到很多读者的私信,问我:“二哥,有什么推荐的学习网站吗?最近很浮躁,手头的一些网站都看烦了,想看看二哥这里有什么新鲜货。” 今天一早做了个恶梦,梦到被老板辞退了。虽然说在我们公司,只有我辞退老板的份,没有老板辞退我这一说,但是还是被吓得 4 点多都起来了。(主要是因为我掌握着公司所有的核心源码,哈哈哈) 既然 4 点多起来,就得好好利用起来。于是我就挑选了 10 个堪称神器的学习网站,推...
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了????,这可都是提升你幸福感的高效率生产力工具哦! 走起!???? NO、1 ScreenToGif 屏幕,摄像头和白板...
阿里面试一个ArrayList我都能跟面试官扯半小时
我是真的没想到,面试官会这样问我ArrayList。
曾经优秀的人,怎么就突然不优秀了。
职场上有很多辛酸事,很多合伙人出局的故事,很多技术骨干被裁员的故事。说来模板都类似,曾经是名校毕业,曾经是优秀员工,曾经被领导表扬,曾经业绩突出,然而突然有一天,因为种种原因,被裁员了,...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
良心推荐,我珍藏的一些Chrome插件
上次搬家的时候,发了一个朋友圈,附带的照片中不小心暴露了自己的 Chrome 浏览器插件之多,于是就有小伙伴评论说分享一下我觉得还不错的浏览器插件。 我下面就把我日常工作和学习中经常用到的一些 Chrome 浏览器插件分享给大家,随便一个都能提高你的“生活品质”和工作效率。 Markdown Here Markdown Here 可以让你更愉快的写邮件,由于支持 Markdown 直接转电子邮...
看完这篇HTTP,跟面试官扯皮就没问题了
我是一名程序员,我的主要编程语言是 Java,我更是一名 Web 开发人员,所以我必须要了解 HTTP,所以本篇文章就来带你从 HTTP 入门到进阶,看完让你有一种恍然大悟、醍醐灌顶的感觉。 最初在有网络之前,我们的电脑都是单机的,单机系统是孤立的,我还记得 05 年前那会儿家里有个电脑,想打电脑游戏还得两个人在一个电脑上玩儿,及其不方便。我就想为什么家里人不让上网,我的同学 xxx 家里有网,每...
史上最全的IDEA快捷键总结
现在Idea成了主流开发工具,这篇博客对其使用的快捷键做了总结,希望对大家的开发工作有所帮助。
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
谁是华为扫地僧?
是的,华为也有扫地僧!2020年2月11-12日,“养在深闺人不知”的华为2012实验室扫地僧们,将在华为开发者大会2020(Cloud)上,和大家见面。到时,你可以和扫地僧们,吃一个洋...
Idea 中最常用的10款插件(提高开发效率),一定要学会使用!
学习使用一些插件,可以提高开发效率。对于我们开发人员很有帮助。这篇博客介绍了开发中使用的插件。
立即提问