C++,两个函数哪个正确为什么
class Test {
private:
    int m_val;
public:

};

下面两个哪个函数写法正确,为什么?

int &get_m_val() const {
    return m_val;
}
const int &get_m_val() const {
    return m_val;
}

c++

1个回答

下面那个是正确的。
或者
int &get_m_val() {
return m_val;
}

weixin_43512948
single dog 好像知道了。。。
8 个月之前 回复
weixin_43512948
single dog 为什么呢??
8 个月之前 回复
foomow
茂大叔独立游戏开发 对是对,不过这样就没法被const对象调用了……
8 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
C++,两个函数哪个正确为什么
``` class Test { private: int m_val; public: }; ``` 下面两个哪个函数写法正确,为什么? ``` int &get_m_val() const { return m_val; } ``` ``` const int &get_m_val() const { return m_val; } ```
C 嵌套调用交换函数swap
我定义了一个数组int a[5]; 声明了两个函数,一个是赋值函数,一个是交换函数 void f1(int *a) { a[0]=1; a[1]=2; } void swap(int *x,int *y) { int *temp; *temp=*x; *x=*y; *y=*temp; } 现在,我要使用函数嵌套调用去交换a[0]与a[1]的值,是这样写是正确的 void f1(int *a) { a[0]=1; a[1]=2; swap(a[0],a[1]); } 还是这样写是正确的? void f1(int *a) { a[0]=1; a[1]=2; swap(&a[0],&a[1]); }
两个类的析构函数互相析构对方的指针
两个类A B ,类A 拥有指针B* b,类B 拥有指针A* a,A析构函数delete b,B析构函数delete a, 造成错误,请问这种情况下如何正确析构两个对象?
对C++成员函数级联调用的一点问题
在C++成员函数级联调用时为什么一定要加&?比如下面这段代码: ``` #include <iostream> using namespace std; class Number { public: Number(int a) { x = a; } Number add(int a) { x += a; return *this; } void print() { cout << x<<endl; } private: int x; }; int main() { int a, b, c; cin >> a >> b >> c; Number n(a); n.add(b).add(c); n.print(); } ``` 输入3,4,5,输出7,只是加了前两个数,如果在Number类的add前面加上&则可得出正确结果,这个&到底有什么作用一定要加?
c语言编程 输入两个加数并计算结果,正确输出对,错误输出错,直道算对为止
为什么我这个程序,计算正确与否都只显示0或1,不显示right wrong #include <stdio.h> int Addtest(int a,int b) { int answer; printf("%d+%d=",a,b); scanf("%d",&answer); if(a+b==answer) return 1; else return 0; } void Print (int flag) { if(flag) printf("Right\n"); else printf ("Notcorrect Try again\n"); } main() { int a,b, answer; printf ("Input a,b"); scanf ("%d,%d",&a,&b); do{ answer=Addtest(a,b); printf(answer); }while(“%d\n”answer==0); }
c++ 通讯录管理系统有个搞不懂的问题
先是创建了两个结构体,联系人结构体和通讯录结构体,代码如下 ``` #define max 1000 //联系人结构体 struct person { //姓名 string name; //性别(1.男 2.女) int sex; //年龄 int age; //家庭住址 string address; //电话号码 string phoneNumber; }; //通讯录结构体 struct addressBook { //通讯录 person personsArray[max]; //储存的成员个数 int number; }; ``` 录入联系人函数代码如下 ``` void addPersons(addressBook* adk ) { if (adk->number == 1000) cout << "通讯录已满" << endl; else { //输入姓名 cout << "请输入联系人姓名" << endl; cin >> adk->personsArray[adk->number].name; //输入性别(1.男 2.女) cout << "请输入联系人性别" << endl; int sex; bool flag = true; while (flag == true) { cin >> sex; if (sex == 1 || sex == 2) { adk->personsArray[adk->number].sex = sex; flag = false; } else cout << "请输入正确的性别" << endl; } //输入年龄 cout << "请输入联系人年龄" << endl; cin >> adk->personsArray[adk->number].age; //输入住址 cout << "请输入联系人家庭住址" << endl; cin >> adk->personsArray[adk->number].address; //输入电话号码 cout << "请输入联系人联系方式" << endl; cin >> adk->personsArray[adk->number].phoneNumber; cout << "录入成功" << endl; adk->number++; } } ``` 如果结构体person中电话号码时int类型,那么在执行完录入函数时会出现系循环,一直重复输出“请输入正确的性别”。 实在是搞不懂,有没有大神帮忙解决下??
我编的这个函数为什么没能实现功能?
7.编写一个函数string_in(),它接受两个字符串指针参数。如果第二个字符串被包含在第一个字符串中,函数就返回被包含的字符开始的地址。例如,string_in("hats","at")返回hats中a的地址,则,函数返回空指针。在一个使用循环语句为这个函数提供输入的完整程序中进行测试。 char *string_in(char *p1,char *p2){ int m = 0; int i; char *p3 = p2; char *p4; while(*p1 != *p2) ++p1; p4 = p1; while(*p3 != '\0'){ p3++; m++; } for(i = 0;i < m;i++){ if(*++p1 != *++p2) return NULL; } return p4; } 正确答案: char *string_in(char *p1,char *p2) { char *p1_save = p1, *p2_save = p2; if(*p1 == '\0' || *p2 == '\0') return NULL; while(1) { if(*p1 == *p2) { if(*++p2 == '\0') return p1_save; if(*++p1 == '\0') return NULL; } else { if(*++p1 == '\0') return NULL; p1_save = p1; p2 = p2_save; } } } 我感觉有点想不到?还有其他方法吗?
C#三角函数与PI的精度问题
为什么Math.Sin(Math.PI/6)=0.5是对的Math.Sin(Math.PI/2)=1也是对的,但是Math.Sin(Math.PI)=1.22460635382238E-16而不是0,计算出错了(sin/cos/tan都有这个问题)。难道是PI的精度不够?那为什么前两个都算的对呢?到底是什么原因?有什么解决办法能让他们都计算正确?谢谢!
一个C++分数计算器的程序,通分函数有错误,求指点,怎么改?
这是两个函数,上面约分函数应该是正确的, 求怎样调用约分函数写通分函数 ``` void Grade::Reduction()//约分 { int a, b, CommonDivisor, Remainder;//公约数,余数 a = abs(numerator);//分子取绝对值 b = abs(denominator);//分母取绝对值 { if (a > b) { Remainder = a % b; while (Remainder != 0) { int t; t = Remainder; a = b; b = t; Remainder = a % b; } CommonDivisor = b; } if (a == b) { CommonDivisor = a; } if (a < b) { Remainder = b % a; while (Remainder != 0) { int t; t = Remainder; b = a; a = t; Remainder = b % a; } CommonDivisor = a; } }//最大公约 numerator /= CommonDivisor;//约分后分子 denominator /= CommonDivisor;//约分后分母 } ``` ``` void Grade::ToCommond(Grade &grade) //通分 { int temp; Reduction(); grade.Reduction(); numerator *= grade.denominator; grade.numerator *= denominator; //////////后面不会写了 ```
编写一程序将两个字符串连接起来
相当于写一个具有strcat函数功能的函数。 ![代码:](https://img-ask.csdn.net/upload/201906/20/1560991860_89024.png) 为什么结果正确,但是后面会有一些乱码? ![图片说明](https://img-ask.csdn.net/upload/201906/20/1560991932_272727.png)
C代码中句子存放不同两个位置,编译都没错,一个运行正确,一个运行出错
#include<stdio.h> //加法运算 int sum(int a, int b) { return a+b ; } //减法运算 int minus(int a, int b) { return a-b ; } void counting(int (*p)(int, int),int a, int b) { if(a <0 || b < 0) { printf("运算的数值<0\n"); return ; } //此处调用指针指向的函数 int result = p(a,b); printf("计算结果:%d\n",result); } int main() { int x,y; char op; //------------------------------问题---------------------------------- //在此处运行正确 printf("请输入运算符(+、-):"); scanf("%c",&op); printf("请输入运算值x="); scanf("%d",&x); printf("请输入运算值y="); scanf("%d",&y); //------------------------------问题---------------------------------- /*为何放此运行会出错???????????? printf("请输入运算符(+、-):"); scanf("%c",&op); */ switch(op) { case '+': //sum(x,y); counting(sum,x,y); //加法 break; case '-': //minus(x,y); counting(minus,x,y); //减法 break; } return 0; }
请求帮忙,非常感谢关于 C语言中函数的!
#include<stdio.h> int M,N; void pr(int w[M][N]) { printf("%d",w[M][N]); } void main() { int a[3][3]; int i,j; for(i=0;i<3;i++) for(j=0;j<3;j++) { printf("a[%d][%d]=",i,j); scanf("%d",&a[i][j]); pr(a); } } 这是一个有错误的程序,下面的是正确的程序,他们两个的区别就在于所定义的被调函数的参数不一样; #include<stdio.h> void pr(int M) { printf("%d\n",M); } void main() { int a[3][3]; int i,j; for(i=0;i<3;i++) for(j=0;j<3;j++) { printf("a[%d][%d]=",i,j); scanf("%d",&a[i][j]); pr(a[i][j]); } } 非常感谢;;
修改程序:信源编解码(c语言)
修改程序:问题1。源文件source文本空间太长汉字太多无法运行2,未按频度要求排序 问题描述: 信源编解码是通信系统的重要组成部分。本实验旨在通过程序设计实现基于哈夫曼编码的信源编解码算法。程序具备以下功能: 对于给定的源文档 SourceDoc.txt, 1) 统计其中所有字符的频度(某字符的频度等于其出现的总次数除以总字符数) , 包括字母(区分大小写) 、标点符号及格式控制符(空格、回车等) 。 2) 按频度统计结果生成哈夫曼编码码表。 3) 基于哈夫曼码表进行编码,生成对应的二进制码流,并输出到文件 Encode.dat。 4) 对二进制码流进行哈夫曼解码,把结果输出到文件 DecodeDoc.txt。 5) 判断DecodeDoc.txt与SourceDoc.txt内容是否一致,以 验证编解码系统的正确性。 要求: 1) 用 C 语言实现。 2) 用子函数实现各功能模块。 3) 输出文件 Statistic.txt,包含的信息有:按频度大小排序的字符表,及各字符出现 的次数、频度及哈夫曼编码。 4) 应至少包含链表、二叉树的数据结构。 5) 不能用冒泡排序算法。 #include<stdio.h> #include<stdlib.h> #include<string.h> #include<sys/stat.h> #include<sys/types.h> #include<fcntl.h> #include<unistd.h> #include<errno.h> #define N 10000 int count = 0; //每增加一个新的字符, count增加1, 可表示a中的字符种类数, 也即哈夫曼树叶子点个数 /*定义哈夫曼树结构体*/ typedef struct HuffmanTree{ int weight; int parent; int Lchild; int Rchild; }HuffmanTree[2*N]; /*定义储存字符及其出现次数的结构体*/ typedef struct DifferentCharacter{ char char_date; int num; //相同字符出现的次数 char a_code[100]; //每种字符对应的编码 }difcha[N]; /*在一定范围内选择两个weight最小的结点, 并将两个结点的序号赋给s1, s2*/ void select_two(HuffmanTree ht, int j, int *s1, int *s2) { int i = 1, temp; int min1 = 0, min2 = 0; while( (ht[i].parent != 0) && (i <= j) ) i++; *s1 = i; min1 = ht[i++].weight; while( (ht[i].parent != 0) && (i <= j) ) i++; *s2 = i; min2 = ht[i++].weight; if(min1 > min2){ temp = min1; min1 = min2; min2 = temp; } for(; i <= j; i++){ //遍历parent不为0的结点 if(ht[i].parent != 0) continue; if(ht[i].weight <= min1){ min2 = min1; min1 = ht[i].weight; *s2 = *s1; *s1 = i; } else if( (ht[i].weight < min2) && (ht[i].weight > min1) ) { min2 = ht[i].weight; *s2 = i; } } } /*建哈夫曼树*/ void EstHuffmanTree(HuffmanTree ht, int *w, int n){ int i; int s1 = 0, s2 = 0; for(i = 1; i <= n; i++){ //初始化哈夫曼树, 前n个单元存放叶子点 ht[i].weight = w[i]; ht[i].parent = 0; ht[i].Lchild = 0; ht[i].Rchild = 0; } for(i = n+1; i <= 2*n-1; i++){ //后n-1个单元存放非叶子点 ht[i].weight = 0; ht[i].parent = 0; ht[i].Lchild = 0; ht[i].Rchild = 0; } for(i = n+1; i <= 2*n-1; i++){ select_two(ht, i-1, &s1, &s2); //创建非叶子点, 建立哈夫曼树, 每次在ht[1]~ht[i-1]范围内选两个最小的weight结点,并将其序号赋给s1, s2 ht[i].weight = ht[s1].weight + ht[s2].weight; ht[i].Lchild = s1; ht[i].Rchild = s2; ht[s1].parent = i; ht[s2].parent = i; } //哈夫曼树建立完毕 } /*求哈弗曼编码*/ void CrtHuffmanCode(HuffmanTree ht, char **hcd, int n){ int start = 0, c = 0, p = 0, i; char *cd = (char*)malloc(n*sizeof(char)); //分配求当前编码的工作空间 cd[n-1] = '\0'; //从左向右存放编码 for(i = 1; i <= n; i++) { start = n-1; //初始化编码起始指针 c = i; p = ht[i].parent; while(p != 0){ start--; if(ht[p].Lchild == c) cd[start] = '0'; //左分支标0 else cd[start] = '1'; //右分支标1 c = p; //向上倒推 p = ht[c].parent; } hcd[i] = (char*)malloc((n-start)*sizeof(char)); strcpy(hcd[i], &cd[start]); } free(cd); } /*自定义错误处理函数*/ void my_err(char *err_string, int line){ printf("Line %d:\n", line); perror(err_string); exit(1); } /*从 buf_read 中统计每个字符出现的次数,将次数作为该字符的权值*/ void Statistics(difcha a, char *buf_read){ int i, j = 0; for(i = 0; i < strlen(buf_read) ; i++){ //对buf_read中的字符遍历 for(j = 0; j < count; j++){ //检查是否是新的字符 if(a[j].char_date == buf_read[i]){ a[j].num++; //若是旧字符, 则num++; break; } } if(j == count){ //若是新字符, 则记录到a中, 且对应的num++ a[count].char_date = buf_read[i]; a[count].num++; count++; //更新count } } } /*从 SourceDoc.txt 读取数据到 buf_read */ void ReadFile(char *pathName, char *buf_read){ int fd_date; int len = 0; if( (fd_date = open(pathName, O_RDWR)) < 0) //以读写方式打开SourceDoc.txt文件 my_err("open SourceDoc.txt", __LINE__); if(lseek(fd_date, 0, SEEK_END) < 0) //获取文件长度,并保持文件读写指针在文件开始处 my_err("lseek", __LINE__); if( (len = lseek(fd_date, 0, SEEK_CUR)) < 0 ) my_err("lseek", __LINE__); if(lseek(fd_date, 0, SEEK_SET) < 0) my_err("lseek", __LINE__); if(read(fd_date, buf_read, len) > len) //从SourceDoc.txt中读取内容 my_err("read SourceDoc.txt", __LINE__); } /*将 buf_code 写入 Encode.dat 中*/ void WriteFile(char *pathName, char *buf_code){ int fd_code; if((fd_code = open(pathName, O_CREAT|O_TRUNC|O_RDWR, S_IRWXU)) < 0) //创建Encode.dat文件 my_err("open Encode.dat", __LINE__); if( write(fd_code, buf_code, strlen(buf_code)) != strlen(buf_code) ) //将 buf_code 写入Encode.dat my_err("write Encode.dat", __LINE__); } /*主函数*/ void main(){ char buf_read[N] = {'\0'}; char buf_code[N] = {'\0'}; char buf_yima[N] = {'\0'}; char *hcd[N]; char temp[50] = {'\0'}; difcha a; int i, j, n, k = 0, m = 0; int w[N] = {0}; HuffmanTree ht; ReadFile("SourceDoc.txt", buf_read); Statistics(a, buf_read); for(i = 0; i < count; i++) w[i+1] = a[i].num; EstHuffmanTree(ht, w, count); //建HuffmanTree CrtHuffmanCode(ht, hcd, count); //对树中字符进行编码 for(i = 1; i <= count; i++) //将每个字符对应的编码存入结构体 a 中 strcpy(a[i-1].a_code, hcd[i]); FILE *fp1; fp1=fopen("Statistic.txt","w"); for(i = 0; i < count; i++) //查看每个字符的权值和对应的编码 fprintf(fp1,"%c %d %s\n", a[i].char_date, a[i].num, a[i].a_code); fclose(fp1); for(i = 0; i < strlen(buf_read) ; i++){ //遍历 buf_read, 给 SourceDoc.txt 中每个字符匹配编码, 存入 buf_code 中 for(j = 0; j < count; j++){ if(buf_read[i] == a[j].char_date){ strcat(buf_code, a[j].a_code); break; } } if(j == count) //匹配异常 printf("Unknown Character: %c\n", buf_read[i]); } WriteFile("Encode.dat", buf_code); //将 buf_code 写入 Encode.dat 中 ReadFile("Encode.dat", buf_read); //从 Encode.dat 中读取全部编码 n = strlen(buf_read); for(i = 0; i < n; i++){ //为 Encode.dat 中的编码匹配字符 temp[k++] = buf_read[i]; for(j = 0; j < count; j++){ if(strcmp(temp, a[j].a_code) == 0){ buf_yima[m++] = a[j].char_date; break; } } if(j < count){ //匹配成功, 对 temp 初始化 for(;k > 0; k--) temp[k] = '\0'; } } FILE *fp2; fp2=fopen("DecodeDoc.txt","w"); fprintf(fp2,"%s", buf_yima); fclose(fp2); }
PTA 1004 成绩排名 C++ 网页提交的时候“部分正确”,找不出来错误。。
PTA 1004 成绩排名,关于这道题,我在dev-c++编译器上运行,按照题示信息进行输入,没有错误,但是在网页提交的时候“部分正确”。 原题: ``` 读入 n(>0)名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。 输入格式: 每个测试输入包含 1 个测试用例,格式为 第 1 行:正整数 n 第 2 行:第 1 个学生的姓名 学号 成绩 第 3 行:第 2 个学生的姓名 学号 成绩 ... ... ... 第 n+1 行:第 n 个学生的姓名 学号 成绩 其中姓名和学号均为不超过 10 个字符的字符串,成绩为 0 到 100 之间的一个整数,这里保证在一组测试用例中没有两个学生的成绩是相同的。 输出格式: 对每个测试用例输出 2 行,第 1 行是成绩最高学生的姓名和学号,第 2 行是成绩最低学生的姓名和学号,字符串间有 1 空格。 输入样例: 3 Joe Math990112 89 Mike CS991301 100 Mary EE990830 95 输出样例: Mike CS991301 Joe Math990112 ``` 代码部分 ``` #include <iostream> #include "string.h" using namespace std; class student { char name[10]; char number[10]; double grade; public: void print(void) { cout << name << " " << number << endl; } friend int main(); //把主函数作为student类的友元函数,方便主函数访问类里的私有成员 }; int main() { char name[10],number[10]; double grade; int num,i=0; cin >> num; student stu[1000]; while (i < num) { cin >> name >> number >> grade; strcpy(stu[i].name, name); strcpy(stu[i].number, number); stu[i].grade = grade; i++; } student *min = stu, *max = stu; //设置两个指针,分别指向有最大、最小成绩的对象 for (i = 1; i < num; i++) { if (stu[i].grade > max->grade) max = &stu[i]; if (stu[i].grade < min->grade) min = &stu[i]; } max->print(); min->print(); return 0; } ``` 网页提交反馈截图: ![图片说明](https://img-ask.csdn.net/upload/201908/02/1564736954_140344.png) 麻烦大佬们有空看看。。。。
自编函数实现strlen 和strcat 我的代码测试结果没问题但是现实运行时错误 求解答
首先请实现如下两个函数(要自己写代码完成,不允许直接调用库函数): int myStrLen(char *s); 该函数功能为求字符串s的长度。 void myStrConcat(char *string1, char *string2); 该函数的功能为将字符串string2拼接至字符串string1后边。注意:该函数的两个参数,在调用时有可能会指向同一个字符串,函数需要在这种情况下能正确完成指定的功能。 主函数要求使用以上两个函数实现如下功能: 输入: 第一行为三个整数n(0<n<10),a,b, 第二行为n个整数,后边为n行字符串,每个字符串长度不超过20。 输出: 要求首先将第b行字符串拼接至第a行的字符串后再输出。 第一行为n个用单个空格分隔的整数(最后一个数后无空格),为按各字符串的输入次序输出的各字符串的长度。 后边n行为将输入的字符串按输入的第2行给出的顺序依次输出。 输入保证合法且字符串中不包含空格。 ``` #include<stdio.h> int myStrLen(char s[]); void myStrConcat(char string1[], char string2[]); int main() { int n,a,b,i,j; int k[20]; char c[20][100]={"0"}; scanf("%d%d%d",&n,&a,&b); for(i=0;i<n;i++)scanf("%d",&k[i]); for(i=0;i<n;i++){ getchar(); scanf("%s",c[i]); } myStrConcat(c[a],c[b]); for(i=0;i<n;i++){ if(i==0)printf("%d",myStrLen(c[i])); else printf(" %d",myStrLen(c[i])); } printf("\n"); for(i=0;i<n;i++)printf("%s\n",c[k[i]]); return 0; } void myStrConcat(char string1[], char string2[]) { int myStrLen(char s[]); int i,j,l1,l2; l1=myStrLen(string1); l2=myStrLen(string2); for(i=l1,j=0;string2[j]!='\0';i++,j++)string1[i]=string2[j]; string1[l1+l2]='\0'; } int myStrLen(char s[]) { int j=0,len=0; for(j=0;s[j]!='\0';j++,len++); return(len); } ```
如何在一个XLL+ 程序中call另外一个XLL+中的函数
大家好,我的问题是,如何在一个XLL+程序中call另外一个XLL+中的函数。 我已经编好并运行成功了一个XLL+ user defined function,函数为sum1,在excel中加入这个add in以后,可以用sum1函数进行运算。现在我开始编写另外一个XLL,e.g.sum2,而在sum2程序中我想直接call sum1函数,然后由于两个函数在两个不同的XLL中,不能直接call,因此需要进行一定的处理才行。请问各位大牛有碰到过这种情况吗?有什么好的代码或者方法可以使用吗? 在网上查了一些,查到下列代码,是用evaluate和UDF function做的,但是这个貌似只适用于visual studio 2005,不适用于2012, 在Visual studio 2012下运行不出正确的结果,会显示#Name error 请各位大牛指导和指正! // Function: CalDaysInYear2 // Purpose: Calls a function in another XLL //{{XLP_SRC(CalDaysInYear2) // NOTE - the FunctionWizard will add and remove mapping code here. // DO NOT EDIT what you see in these blocks of generated code! IMPLEMENT_XLLFN2(CalDaysInYear2, "RI", "CalDaysInYear2", "DayCount", "Date & Time", "Calls a function in another XLL," " which returns number of days in a year according to the" " day count", "Day count convention\000", "\0appscope=1\0", 1) extern "C" __declspec( dllexport ) LPXLOPER CalDaysInYear2(short DayCount) { XLL_FIX_STATE; CXlOper xloResult; //}}XLP_SRC static int xlfEvaluate = 257; static int xlUDF = 255; CXlOper xloName, xloRef; int rc = 0; xloName = "CalDaysInYear"; if (!rc) rc = xloRef.Excel(xlfEvaluate, 1, &xloName); if (!rc) rc = xloResult.Excel(xlUDF, 2, &xloRef, &CXlOper(DayCount, 0)); return xloResult.Ret(); }
用c语言编写以下程序:输入十个职员的姓名和工号,并按工号大小进行排序,姓名顺序也随之排序
![图片说明](https://img-ask.csdn.net/upload/201912/15/1576379213_109059.png) `````` //输入10个员工的工号和姓名,并将其以工号大小排序,姓名随之排序 #include<stdio.h> #include<string.h> #define N 3 //为了方便起见输入三个信息来测试代码 struct WORKERS //存放职员的信息 { int num; //工号 char name[20]; //姓名 }worker[N]; void input_(); //输入员工信息 void sort(); //排序 int main() { input_(); sort(); return 0; } void input_() { int i; printf("工号 姓名"); for(i=0;i<N;i++) { scanf("%d %s",&worker[i].num,&worker[i].name); } } void sort() { int i,j; int *ntemp; //储存工号的中间变量 char *stemp; //储存姓名的中间变量 for(i=0;i<N;i++) //冒泡法排序 { for(j=0;j<N-i;j++) { if(worker[j].num>worker[j+1].num) { ntemp=worker[j+1].num; worker[j+1].num=worker[j].num; worker[j].num=ntemp; strcpy(stemp,worker[j+1].name); strcpy(worker[j+1].name,worker[j].name); strcpy(worker[j].name,stemp); } } } for(i=0;i<N;i++) { printf("%d %s\n",worker[i].num,worker[i].name); } } ```这个程序中需要使用结构体,指针等内容,并使用两个函数实现,我的代码中出现了[Error] invalid conversion from 'int' to 'int*' [-fpermissive]这个错误 在测试时出现第三项无法正确输出的错误,如图片所示 已经解决了,以下是正确代码 //输入10个员工的工号和姓名,并将其以工号大小排序,姓名随之排序 #include<stdio.h> #include<string.h> #define N 3 //为了方便起见输入三个信息来测试代码 struct WORKERS //存放职员的信息 { int num; //工号 char name[20]; //姓名 } worker[N]; void input_(); //输入员工信息 void sort(); //排序 int main() { input_(); sort(); return 0; } void input_() { int i; printf("工号 姓名\n"); for (i = 0; i < N; i++) { scanf("%d %s", &worker[i].num, &worker[i].name); } } void sort() { int i, j; int ntemp; //储存工号的中间变量 char *stemp=&worker; //储存姓名的中间变量 printf("排序后员工信息列表\n"); for (i = 0; i < N - 1; i++) //冒泡法排序 { for (j = 0; j < N - i - 1; j++) { if (worker[j].num > worker[j + 1].num) { ntemp = worker[j + 1].num; worker[j + 1].num = worker[j].num; worker[j].num = ntemp; strcpy(stemp, worker[j + 1].name); strcpy(worker[j + 1].name, worker[j].name); strcpy(worker[j].name, stemp); } } } for (i = 0; i < N; i++) { printf("%d %s\n", worker[i].num, worker[i].name); } } ``` ```
c++中,同一个project 中不同cpp之间用对象调用函数,断点显示并没有调用成功
比如在同一个项目下有两个cpp //a.cpp//只是简单示意一下,不是正确代码 class ff {ff::function() {.....; } } //b.cpp include a.h; ff f1;//新建一个类ff的对象 f1.function(); 程序能够正常运行,得到正确结果,可是当我在f1.function;前打断点的时候,断点显示程序是可以执行这个语句的,但是在ff::function()之前的断点在run程序时就会变成![图片说明](https://img-ask.csdn.net/upload/201508/17/1439788199_641815.png) 就是标在 a.cpp中ff::function()函数语句前的断点会如图显示 请问是为什么呢?是项目属性设置有问题吗?
C语言的scanf无法正确读入信息
这是一个读入多项式的函数,没有语法错误。但是在我输入完我需要的数 之后,无法正确响应。不知道自己错在哪了。大哥们,能不能帮我看看。 ```#include<stdio.h> #include<stdlib.h> typedef struct polynode * polynomial; polynomial readpoly(); struct polynode { int expon; int coef; polynomial next; }; int main() { /*用p1,p2来定位两个多项式。*/ polynomial p1, p2; p1 = readpoly(); p2 = readpoly(); while(p1!=NULL) printf("%d", p1->expon); return 0; } polynomial readpoly() { int e, c, N; polynomial p, phead;/*p 为工作指针 phead 一直指向头结点*/ p = (polynomial)malloc(sizeof(struct polynode)); phead = p;//phead指向第一个节点 printf("请输入项数"); scanf("%d", &N); printf("请输入每项的系数与指数"); while(N--) { scanf("%d%d", &c, &e); p->coef = c; p->expon = e; p = p->next; p->next = NULL; } return phead; } 下面是我的输入,在输入完后,是这样: ![图片说明](https://img-ask.csdn.net/upload/201904/28/1556442057_364925.png) 这个问题会在我试图输入多个值的时候出现,那里出了问题? ```
Visual studio2010 用多文件结构出现error c2085
具体情况是: 本来程序都是正确的能运行 但是在制作完成两个新的函数并插入到MAIN函数里后出现 error C2085: “yanzhengok”: 不在形参表中;error C2085: “creat”: 不在形参表中;……之前所有插入到main函数里本来能用的都显示这个错误了 请各位大大们指教 多谢!
130 个相见恨晚的超实用网站,一次性分享出来
相见恨晚的超实用网站 持续更新中。。。
字节跳动视频编解码面经
三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时想着能进去就不错了,管他哪个岗呢,就同意了面试...
win10系统安装教程(U盘PE+UEFI安装)
一、准备工作 u盘,电脑一台,win10原版镜像(msdn官网) 二、下载wepe工具箱 极力推荐微pe(微pe官方下载) 下载64位的win10 pe,使用工具箱制作启动U盘打开软件, 选择安装到U盘(按照操作无需更改) 三、重启进入pe系统 1、关机后,将U盘插入电脑 2、按下电源后,按住F12进入启动项选择(技嘉主板是F12) 选择需要启...
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch, ...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Java描述设计模式(19):模板方法模式
本文源码:GitHub·点这里 || GitEE·点这里 一、生活场景 通常一款互联网应用的开发流程如下:业务需求,规划产品,程序开发,测试交付。现在基于模板方法模式进行该过程描述。 public class C01_InScene { public static void main(String[] args) { DevelopApp developApp = n...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n...
第三个java程序(表白小卡片)
前言: &nbsp;向女神表白啦,作为一个程序员,当然也有爱情啦。只不过,虽然前面两个程序都只是学习了基础的语法结构和向量哈希表。这里涉及的是Swing,awt图形用户界面和一点文件输入输出流的知识。 &nbsp; 表白代码如下: 另附:里面的音乐和图片可以放在一个自己创建的包里面,也可以放在src里面,或者使用绝对路径。至于布局,我自己的使用的是简单的排班,简单的继承。后面的程序会慢慢实现。 ...
8年经验面试官详解 Java 面试秘诀
作者 |胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。 Java程序员准备和投递简历的实...
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的回答,对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalking,作者吴晟、刘浩杨 等等 仓库地址: apache/skywalking 更...
化繁为简 - 腾讯计费高一致TDXA的实践之路
导语:腾讯计费是孵化于支撑腾讯内部业务千亿级营收的互联网计费平台,在如此庞大的业务体量下,腾讯计费要支撑业务的快速增长,同时还要保证每笔交易不错账。采用最终一致性或离线补...
Linux网络服务-----实验---PXE和Kickstart的无人值守装机
目录 一.PXE的原理 二.kickstart的原理 三.PXE与kickstart的结合使用自动装机 一.PXE的原理 PXE(preboot execute environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服务器下载映像,并由支持通过网络启动操作系统,再启动过程中,终端要求服务器分配IP地址...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
A*搜索算法概述
编者按:本文作者奇舞团前端开发工程师魏川凯。A*搜索算法(A-star search algorithm)是一种常见且应用广泛的图搜索和寻径算法。A*搜索算法是通过使用启...
程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca...
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆每天早上8:30推送 作者|Mr.K 编辑| Emma 来源|技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯...
从顶级黑客到上市公司老板
一看标题,很多老读者就知道我在写什么了。今天Ucloud成功上市,季昕华成为我所熟悉的朋友里又双叒叕一个成功上市的案例。我们认识大概是十五年多吧,如果没记错,第一次见面应该是2004年,...
蓝桥杯知识点汇总:基础知识和常用算法
文章目录基础语法部分:算法竞赛常用API:算法部分数据结构部分 此系列包含蓝桥杯绝大部分所考察的知识点,以及真题题解~ 基础语法部分: 备战蓝桥杯java(一):一般输入输出 和 快速输入输(BufferedReader&amp;BufferedWrite) 备战蓝桥杯java(二):java编程规范和常用数据类型 备战蓝桥杯java(三):常用功能符以及循环结构和分支结构 备战蓝桥杯java(四...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
破14亿,Python分析我国存在哪些人口危机!
一、背景 二、爬取数据 三、数据分析 1、总人口 2、男女人口比例 3、人口城镇化 4、人口增长率 5、人口老化(抚养比) 6、各省人口 7、世界人口 四、遇到的问题 遇到的问题 1、数据分页,需要获取从1949-2018年数据,观察到有近20年参数:LAST20,由此推测获取近70年的参数可设置为:LAST70 2、2019年数据没有放上去,可以手动添加上去 3、将数据进行 行列转换 4、列名...
强烈推荐10本程序员在家读的书
很遗憾,这个春节注定是刻骨铭心的,新型冠状病毒让每个人的神经都是紧绷的。那些处在武汉的白衣天使们,尤其值得我们的尊敬。而我们这些窝在家里的程序员,能不外出就不外出,就是对社会做出的最大的贡献。 有些读者私下问我,窝了几天,有点颓丧,能否推荐几本书在家里看看。我花了一天的时间,挑选了 10 本我最喜欢的书,你可以挑选感兴趣的来读一读。读书不仅可以平复恐惧的压力,还可以对未来充满希望,毕竟苦难终将会...
Linux自学篇——linux命令英文全称及解释
man: Manual 意思是手册,可以用这个命令查询其他命令的用法。 pwd:Print working directory 意思是密码。 su:Swith user 切换用户,切换到root用户 cd:Change directory 切换目录 ls:List files 列出目录下的文件 ps:Process Status 进程状态 mkdir:Make directory ...
Python实战:抓肺炎疫情实时数据,画2019-nCoV疫情地图
今天,群里白垩老师问如何用python画武汉肺炎疫情地图。白垩老师是研究海洋生态与地球生物的学者,国家重点实验室成员,于不惑之年学习python,实为我等学习楷模。先前我并没有关注武汉肺炎的具体数据,也没有画过类似的数据分布图。于是就拿了两个小时,专门研究了一下,遂成此文。
疫情数据接口api
返回json示例 { "errcode":0,//0标识接口正常 "data":{ "date":"2020-01-30 07:47:23",//实时更新时间 "diagnosed":7736,//确诊人数 "suspect":12167,//疑是病例人数 "death":170,//死亡人数 "cur...
智力题(程序员面试经典)
NO.1  有20瓶药丸,其中19瓶装有1克/粒的药丸,余下一瓶装有1.1克/粒的药丸。给你一台称重精准的天平,怎么找出比较重的那瓶药丸?天平只能用一次。 解法 有时候,严格的限制条件有可能反倒是解题的线索。在这个问题中,限制条件是天平只能用一次。 因为天平只能用一次,我们也得以知道一个有趣的事实:一次必须同时称很多药丸,其实更准确地说,是必须从19瓶拿出药丸进行称重。否则,如果跳过两瓶或更多瓶药...
相关热词 c# 为空 判断 委托 c#记事本颜色 c# 系统默认声音 js中调用c#方法参数 c#引入dll文件报错 c#根据名称实例化 c#从邮件服务器获取邮件 c# 保存文件夹 c#代码打包引用 c# 压缩效率
立即提问

相似问题