大一c语言企业员工管理系统(救救孩子吧)

1.网上嫖了一个,但是看不懂(上课摸鱼的那种),想加一个排序,但是加不进去
2.就是吧录入进去的按年龄排序就行了 就差个排序了55
图片说明
图片说明
3.先谢谢大佬们55

如下
#include
#include
#include "windows.h"
using namespace std;
#include
#include
#define N 100

typedef struct phone
{
char num[30];
char name[50];
char sex[10];
char year[50];
char school[50];
char zhiwei[50];
char money[10];
char address[30];
char tel[30];
struct phone *next;
}phone,p[100];

phone *head;
void Initiate();
void Menu();
phone *Create();//创建
void Find();
void Alter();
void Delete();
void List();
phone *write_in();
phone *write_out();
void count();
void tongji();
void paixu();

phone *write_in(phone *head)
{
FILE *fp;
phone *p;
if((fp=fopen("D:职工信息.txt","w"))==NULL)
{
printf("无法打开文件!!!\n");
exit(0);
}
p=head->next;
if(head!=NULL)
while(p!=NULL)
{
fprintf(fp,"%s %s %s %s %s %s %s %s %s",p->num,p->name,p->sex,p->year,p->school,p->zhiwei,p->money,p->address,p->tel);
fprintf(fp,"\r\n");
p=p->next;
}
fclose(fp);
return head;
}
phone *write_out()
{
FILE *fp;
phone *p,*pre,*tail;
head=(phone *)malloc(sizeof(phone));
strcpy(head->num,"\0");
strcpy(head->name,"\0");
strcpy(head->sex,"\0");
strcpy(head->year,"\0");
strcpy(head->school,"\0");
strcpy(head->zhiwei,"\0");
strcpy(head->money,"\0");
strcpy(head->address,"\0");
strcpy(head->tel,"\0");
tail = pre=head;
fp=fopen("D:职工信息.txt","r");
if(fp==NULL)
{
printf("文件打开失败!!!");
exit(0);
}
p=(phone *)malloc(sizeof(phone));
p->next=NULL;
head->next=NULL;
while(fscanf(fp,"%s %s %s %s %s %s %s %s %s",p->num,p->name,p->sex,p->year,p->school,p->zhiwei,p->money,p->address,p->tel)!=EOF)
{
pre = tail;
tail->next=p;
tail=p;
p=(phone *)malloc(sizeof(phone));
p->next=NULL;
}
fclose(fp);
return head;
}
//初始化
void Initiate()
{
if((head=(phone *)malloc(sizeof(phone)))==NULL)
exit(1);
head->next=NULL;
}
//主体菜单
void Menu()
{

printf("*********************************************欢迎使用企业职工信息管理系统***********************************************");
printf("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@1.录入员工信息.@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@");

printf("\n");
printf("?????????????????????????2.查询员工信息.???????????????????????????"); 
printf("\n");
printf("++++++++++++++++++++++++++++++++++++++++++++++++++3.修改员工信息.++++++++++++++++++++++++++++++++++++++++++++++++++++++"); 
printf("\n");
printf("—————————————————————————4.删除员工信息!—————————————————————————— ");
printf("\n");
printf("                                        ★        5.显示所有员工信息.                                                         "); 
    printf("                                        ★        6.统计员工信息.                                                         ");
printf("                                                  7.排序员工信息.");
printf("                                                  0.退出系统."); 
printf("                                                                                                制作人   ");
system("pause");

}

//录入
phone *Create()
{
phone *p1,*p2;
int m,i;
printf("请输入创建个数:");
scanf("%d",&m);
for(i=1;i<=m;i++)
{
p1=(phone *)malloc(sizeof(phone));
printf("请输入第%d条信息!\n",i);
printf("请输入职工号:\n");
scanf("%s",p1->num);
printf("姓名:\n");
scanf("%s",p1->name);
printf("性别:\n");
scanf("%s",p1->sex);
printf("出生年月:\n");
scanf("%s",p1->year);
printf("学历:\n");
scanf("%s",p1->school);
printf("职务:\n");
scanf("%s",p1->zhiwei);
printf("工资:\n");
scanf("%s",p1->money);
printf("地址:\n");
scanf("%s",p1->address);
printf("电话:\n");
scanf("%s",p1->tel);

    p1->next=NULL;
    if(head->next==NULL)
       head->next = p1;
    else
    {
        for(p2=head;p2->next!=NULL;p2=p2->next);       //找到结点尾
        p2->next = p1;
    }
 }
printf("信息已添加!\n");
head=write_in(head);
return head;
                                  //保存到链表

}

//查找员工信息
void Find()
{
phone *p;
char name[50];
if(head->next==NULL)
{
printf("此系统为空!\n");
return;
}
printf("请输入要查找的姓名:\n");
scanf("%s",&name);
for(p=head->next;p!=NULL;p=p->next)
{
if(strcmp(p->name,name)==0)
{
printf("职工号\t姓名\t性别\t出生年月\t学历\t职务\t工资\t地址\t电话\n");
printf("%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s\n",p->num,p->name,p->sex,p->year,p->school,p->zhiwei,p->money,p->address,p->tel);
}
else if(p->next==NULL)
printf("无此信息!\n");
}
head=write_in(head);
}
//修改员工信息
void Alter()
{
head=write_out();
char name[50]; //先查找 后删除
phone *p=head->next;
if (p == NULL)
{
printf("此系统为空!\n");
return;
}
printf("请输入要修改的姓名:\n");
scanf("%s",name);
while(p!=NULL)
{
if(strcmp(p->name,name)==0)
{
printf("请输入需要插入的信息");
printf("姓名:\n");
scanf("%s",p->name);
printf("性别:\n");
scanf("%s",p->sex);
printf("出生年月:\n");
scanf("%s",p->year);
printf("学历:\n");
scanf("%s",p->school);
printf("职务:\n");
scanf("%s",p->zhiwei);
printf("工资:\n");
scanf("%s",p->money);
printf("地址:\n");
scanf("%s",p->address);
printf("电话:\n");
scanf("%s",p->tel);
break;
}
}
printf("修改成功");
head=write_in(head);
}

//删除员工信息
void Delete()
{
head=write_out();
char name[50]; //先查找 后删除
phone *p = head->next, *p1 =head->next,*p2;

if (head->next == NULL)
{
printf("此通讯录为空!\n");
return;
}
printf("请输入要删除的姓名:\n");
scanf(" %s",name);
while ((strcmp(p->name,name)!=0 )&& p->next != NULL)
{
p1=p;
p =p->next;
}
if (strcmp(name, p->name)==0) //输出删除信息
{
if (p == head->next&&p->next!=NULL)
head->next = p->next;
else if(p==head->next&&p->next==NULL)
{
head->next=p->next;
printf("信息已删除,先此通讯录为空!!\n");
return;
}
else
p1->next = p->next;
}
else
{
printf("此信息不存在!!!\n");
return;
}
printf("此信息已删除!");
printf("职工号\t姓名\t性别\t出生年月\t学历\t职务\t工资\t地址\t电话\n");
for(p2=head->next;p2!=NULL;p2=p2->next)
printf("%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s\n",p->num,p->name,p->sex,p->year,p->school,p->zhiwei,p->money,p->address,p->tel);
head=write_in(head);
}
//显示所有员工记录
void List()
{
head=write_out();
phone *p;
if(head->next==NULL)
{
printf("此系统中无记录!\n");
return;
}
printf("职工号\t姓名\t性别\t出生年月\t学历\t职务\t工资\t地址\t电话\n");
for(p=head->next;p!=NULL;p=p->next)
printf("%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s\n",p->num,p->name,p->sex,p->year,p->school,p->zhiwei,p->money,p->address,p->tel);
}

int main()
{
int choice;
char yes_no;

Initiate();

do
{
Menu();
printf("请选择0-5的数字\n");
scanf("%d",&choice);
printf("\n");
switch(choice)
{
case 1:Create();
break;
case 2:Find();
break;
case 3:Alter();
break;
case 4:Delete();
break;
case 5:List();
break;
case 6:tongji();
break;
case 7:paixu();
break;
case 0:
printf("************感谢您的使用************\n");
exit(0);
break;
default:
printf("输入有误!请重新输入\n");
break;
}
printf("是否继续 Y or N? \n");
do
{
scanf("%c",&yes_no);
}while(yes_no!='Y'&&yes_no!='y'&&yes_no!='N'&&yes_no!='n');
}while(yes_no=='Y'||yes_no=='y');
}

enum Color

{

black, blue, green, lakeBlue, red, purple, yellow, white, gray,

lightBlue, lightGreen, lightSimpleGreen, lightRed, lightPurple, lightYellow, brightWhite

};

void setColor(unsigned short backColor=0, unsigned short textColor=7){

char command[9]="color 07";     //默认颜色  

command[6]='0'+backColor;       //将backColor变量改为字符型 

command[7]='0'+textColor;       //将textColor变量改为字符型 

system(command);                //调用系统函数 

}
void tongji()
{
int n=0;
phone *p;
char school[50];
if(head->next==NULL)
{
printf("此系统为空!\n");
return;
}
printf("请输入要查找的学历:\n");
scanf("%s",&school);
for(p=head->next;p!=NULL;p=p->next)
{
if(strcmp(p->school,school)==0)
{
printf("职工号\t姓名\t性别\t出生年月\t学历\t职务\t工资\t地址\t电话\n");
printf("%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s\n",p->num,p->name,p->sex,p->year,p->school,p->zhiwei,p->money,p->address,p->tel);
n++;
}
else if(p->next==NULL)
printf("无此信息!\n");
}
printf("该学历人数有%d",n);
printf("\n");
head=write_in(head);
}

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
c语言,迷宫问题,救救孩子
该计划以此为基础它基于以下修改。 (1)指定任意位置(row,col)作为目的地而不是出口(EXIT)寻找路径。 (2)不要使用make[] []数组。 (3)当您第一次到达某个位置时,当在8个方向的相邻位置中存在目的地时,路径搜索结束。 (4)每次都随机确定寻找路径的方向。 校正方法的概要如下。 (1)指定DST_ROW和DST_COL的值而不是EXIT_ROW和EXIT_COL (2)当转到位置(i,j)时,将迷宫[i] [j]的值从0修改为-1 (3)如果它到达位置(i,j),它检查是否有8个方向相邻位置(DST_ROW,DST_COL) (4)在回溯中,让我们说(i,j,dV)从堆栈顶部弹出的内容。 dV是表示关于移动方向的信息的方向矢量,并且数据类型是整数。例如,如果dV是41,则它是8位二进制数00101001。每个位可以被称为0位,1位,......,7位来自最低有效位,位0的位0是方向N,位1是方向NE,....位7是方向它对应于西北。比特1表示方向是阻止或已经消失,值0表示尚未尝试方向。在用位置(i,j)回溯之后,从方向矢量的8位的0位指示的方向之一中随机选择尝试的方向。例如,假设dV = 41 = 00101001具有5位0,并且如果选择对应于NW的7位,如果判断移动到NW是合法移动,则移动到该位置,并且在堆栈上移动的值是(i,j,169)。因为8位二进制数10101001是十进制数169。 (A)在所示程序中,编写C代码以填充path()函数中的空白'a'和'b'。 (b)为什么C代码用'a'和'b'写,为什么没有不必要的操作 解释你需要知道和解释的内容。 (c)呈现执行(a)中完成的程序的屏幕,使用的10×10迷宫数据和目的地坐标。 解释你需要解释的内容。 #include "stdafx.h" #include <stdlib.h> #include <math.h> #define TRUE 1 #define FALSE 0 #define numRow 10 #define numCol 10 #define DST_ROW 5 // Destination coordinates row #define DST_COL 6 // Destination coordinates col #define stack_size 100 typedef struct { int row; int col; int dir_vector; // See below for a description of the direction vector. } element; typedef struct { short int vert; short int horiz; } offsets; void setup_maze(); void set_move(); void path(); int init_dir_vector(int row, int col); // Description in function definition int get_next_dir(int dir_vector); // Description in function definition void push(element position); element pop(); int top = -1; offsets move[8]; short int maze[numRow + 2][numCol + 2]; element stack[stack_size]; void main() { setup_maze(); set_move(); path(); } void setup_maze() { int i, j; short int maze0[numRow][numCol] = { { 0,0,1,0,1,1,1,0,1,0 }, { 1,0,0,1,1,1,0,1,0,1 }, { 1,1,0,1,1,0,1,0,1,1 }, { 0,0,1,0,1,1,1,0,0,0 }, { 0,1,1,0,1,0,1,0,1,0 }, { 1,0,1,1,1,1,0,0,1,0 }, { 1,1,0,1,0,1,0,0,1,0 }, { 1,0,0,0,1,0,1,0,0,0 }, { 0,1,0,1,1,1,0,1,1,0 }, { 1,0,0,1,1,1,0,0,0,0 } }; // Inbound coordinates (1,1) are not allowed if (DST_ROW == 1 && DST_COL == 1) { printf("\nThe coordinate of destination should be different from that of entrance (1,1)."); exit(0); } // Destination is not blocked. if (maze0[DST_ROW - 1][DST_COL - 1] == 1) { printf("\nmaze[DST_ROW][DST_COL] should be 0."); exit(0); } for (i = 0; i < numCol + 2; i++) maze[0][i] = 1; for (i = 0; i < numCol + 2; i++) maze[numRow + 1][i] = 1; for (i = 0; i < numRow + 2; i++) maze[i][0] = 1; for (i = 0; i < numRow + 2; i++) maze[i][numCol + 1] = 1; for (i = 1; i <= numRow; i++) for (j = 1; j <= numCol; j++) maze[i][j] = maze0[i - 1][j - 1]; } void set_move() { move[0].vert = -1; move[0].horiz = 0; move[1].vert = -1; move[1].horiz = 1; move[2].vert = 0; move[2].horiz = 1; move[3].vert = 1; move[3].horiz = 1; move[4].vert = 1; move[4].horiz = 0; move[5].vert = 1; move[5].horiz = -1; move[6].vert = 0; move[6].horiz = -1; move[7].vert = -1; move[7].horiz = -1; } void push(element position) { stack[++top] = position; } element pop() { element position; position = stack[top--]; return position; } void path() { int i, row, col, nextRow, nextCol, dir, dir_vector, found = FALSE; element position; row = 1; col = 1; maze[1][1] = -1; dir_vector = init_dir_vector(1, 1); if (dir_vector == -1) found = TRUE; //(1,1)의 바로 이웃에 목적지가 있음 else { top = 0; stack[0].row = 1; stack[0].col = 1; stack[0].dir_vector = dir_vector; } while (top > -1 && !found) { position = pop(); 'A' while (dir < 8 && !found) { nextRow = row + move[dir].vert; nextCol = col + move[dir].horiz; 'B' } } if (found) { printf("The path is:\n"); printf("row col\n"); for (i = 0; i <= top; i++) printf("%2d%5d\n", stack[i].row, stack[i].col); printf("%2d%5d\n", row, col); printf("%2d%5d\n", DST_ROW, DST_COL); } else printf("The maze does not have a path\n"); } int init_dir_vector(int row, int col) { // input: Position coordinates // output: -1 or an integer value in the range 0 to 255 (= 2 ^ 8-1) // // If there is a destination among eight directional neighbors of a location (row, col), return -1 to terminate the route search, // If it does not exist, it initializes a direction vector represented by an integer value ranging from 0 to 255 (= 2 ^ 8-1) // // direction vector: An 8-bit string expressed as an integer value corresponding to its size // call bits 0, 1, ..., 7 from the least significant bit // bit i corresponds to direction i (i = 0, ..., 7). Example: bit 0 is north, bit 1 is north-east, ... // i bit = 1: direction i indicates that you have already tried in the path finding // i bit = 0: Indicate that i has not yet visited direction i // Initialize direction vector of position (row, col): For each of 8 directions of position (row, col), it can not be blocked // Set the corresponding bit of the direction vector to 1 if it has already gone, otherwise set it to 0. // How to perform initialization (below code): If all 8 bits are set to 1 and check each direction, reset the corresponding bit to 0 int dir, nextRow, nextCol, dir_vector; dir_vector = ((int)pow(2.0, 8.0)) - 1; // dir_vector = 255 in decimal, 11111111 in binary (8 bits in all) for (dir = 0; dir < 8; dir++) { nextRow = row + move[dir].vert; nextCol = col + move[dir].horiz; if (nextRow == DST_ROW && nextCol == DST_COL) return -1; // to report that a path is found if (!maze[nextRow][nextCol]) dir_vector -= (int)pow(2.0, (double)dir); } return dir_vector; } int get_next_dir(int dir_vector) { // input: direction vector (an integer value in the range 0-255 (= 2 ^ 8-1)) // output: direction value 0..7 or 8 // // Take the integer value representing the direction vector and set the 1 or 0 value of each 8 bits // Move to an array of size 8 (array d [8] in the code below) // Randomly selects one of the 0 bits and returns the direction value (0..7) corresponding to that bit // If there are no 0 bits, return 8 to do backtrack int dir, d[8], count, k; for (dir = 0; dir < 8; dir++) { d[dir] = dir_vector % 2; dir_vector /= 2; } // count = number of 0 bits in direction vector count = 0; for (dir = 0; dir < 8; dir++) if (d[dir] == 0) count++; if (count == 0) return 8; // Randomly select one of the count 0 bits and return the corresponding direction value (0..7) k = rand() % count + 1; for (dir = 0; dir < 8; dir++) { if (d[dir] == 0) k--; if (k == 0) return dir; } }
c语言位运算,大佬们救救萌新吧
![图片说明](https://img-ask.csdn.net/upload/201911/26/1574739046_205820.png) 定义函数unsigned mod(unsigned a, unsigned b, unsigned c); 功能是计算并返回a*b%c的结果。要求考试a, b, c的范围是大于0且小于 231,程序不能使用64位整型(如:long long类型或__int64)求解。 问题:a*b可能溢出(超出32位unsigned int型的表示范围)。为解决此问题,可用如下算法。 设unsigned型变量b的每个二进制位为xi (i=0,1, …, 31),i=0为最低位,i=31为最高位,则 , 所以 上式中,a*xi的结果或者为a或者为0; *2运算可用左移1位操作实现(小于231的整数*2结果一定小于232, 不会发生溢出); %c的结果是小于c的,而c小于231,它与a求和也不会发生溢出。 编写完整程序,用迭代法实现上述算法。 要求测试b的每个二进制xi位为1或0的操作必须采用位运算实现。 输入提示:"Input unsigned integer numbers a, b, c:\n" 输入格式:"%u%u%u" 输出格式:"%u*%u%%%u=%u\n" 源程序代码:
matlab求救,救救孩子吧
救救孩子吧 ![图片说明](https://img-ask.csdn.net/upload/201907/20/1563553344_957260.png) ![图片说明](https://img-ask.csdn.net/upload/201907/20/1563553356_275101.jpg) 两个结果不一样
救救孩子吧!如何解决读取txt文件出现索引超出了数组的范围的问题
#include<stdio.h> #include<stdlib.h> void main() { typedef struct LNode { char name[6]; int no; int yw; int sx; int yy; struct LNode* next; }LinkList; struct NameNo { int no; int yw; int sx; int total; char name[6]; }st[10]; FILE* fp, * fp1; char ch, sname[6]; int x, i, j; NameNo tmp; LinkList* p, * s; printf("\n"); printf("-------------------------------"); printf("学生成绩管理系统"); printf("--------------------------------"); printf("\n\n"); printf("在您的C盘根目录下是否有cj1.txt和cj2.txt文件?如果有请输入1,"); printf("否则输入0;如果没有,那么程序将终止!1 or 0?"); scanf("%d", &i); if (i == 0) return; printf("\n\n"); printf("对cj1.txt和cj2.txt进行合成请按''"); scanf("%d", &i); if (i != 1) return; printf("正在把cj1.txt和cj2.txt中的数据进行合并\n"); printf("......\n.....\n....\n...\n..\n.\n"); if ((fp = fopen("c:\\cj1.txt", "rt")) == NULL) //从文本文件cj1.txt中读取数据传向cj3.txt { printf("无cj1.txt文本文件,程序结束。\n"); return; } fp1 = fopen("c:\\cj3.txt", "wt"); ch = fgetc(fp); while (ch != EOF) { fputc(ch, fp1); ch = fgetc(fp); } fclose(fp1); fclose(fp); if ((fp = fopen("c:\\cj2.txt", "rt")) == NULL) //从文本文件cj2.txt中读取数据接到cj3.txt的后面 { printf("无cj12.txt文本文件,程序结束。\n"); return; } fp1 = fopen("c:\\cj3.txt", "a"); for (i = 0; i < 37; i++) fgetc(fp); ch = fgetc(fp); while (ch != EOF) { fputc(ch, fp1); ch = fgetc(fp); } fclose(fp1); fclose(fp); printf("合并成功!现在你可以在C盘根目录下看到一个cj3.txt文件\n"); printf("\n\n"); p = (LinkList*)malloc(sizeof(LinkList)); p->next = NULL; fp = fopen("c:\\cj3.txt", "rt");//从合成后的cj3.txt读取数据,生成链表 for (i = 0; i < 36; i++) fgetc(fp); ch = fgetc(fp); while (ch != EOF) { s = (LinkList*)malloc(sizeof(LinkList)); fgets(s->name, 6, fp); for (i = 0; i < 5; i++) fgetc(fp); x = fgetc(fp) - 48; x = x * 10 + fgetc(fp) - 48; s->no = x; for (i = 0; i < 5; i++) fgetc(fp); x = fgetc(fp) - 48; x = x * 10 + fgetc(fp) - 48; s->yw = x; for (i = 0; i < 5; i++) fgetc(fp); x = fgetc(fp) - 48; x = x * 10 + fgetc(fp) - 48; s->sx = x; for (i = 0; i < 5; i++) fgetc(fp); x = fgetc(fp) - 48; x = x * 10 + fgetc(fp) - 48; s->yy = x; s->next = p->next; p->next = s; ch = fgetc(fp); } fclose(fp); printf("对cj3.txt中有不及格的学生信息生成cj4.txt请按''"); scanf("%d", &i); if (i != 1) return; printf("正在生成cj4.txt\n"); printf("......\n.....\n....\n...\n..\n.\n"); if (i == 1) fp = fopen("c:\\cj4.txt", "wt");//把三科成绩中有补考的学生信息放入cj4.txt fputs("姓 名 学号 语文 数学 英语", fp); fclose(fp); fp = fopen("c:\\cj4.txt", "a"); s = p->next; while (s != NULL) { if (s->yw < 60 || s->sx < 60 || s->yy < 60) { ch = '\n'; fputc(ch, fp); fputs(s->name, fp); for (i = 0; i < 5; i++) { ch = ' '; fputc(ch, fp); } ch = s->no / 10 + 48; fputc(ch, fp); ch = s->no - (s->no / 10) * 10 + 48; fputc(ch, fp); for (i = 0; i < 5; i++) { ch = ' '; fputc(ch, fp); } ch = s->yw / 10 + 48; fputc(ch, fp); ch = s->yw - (s->yw / 10) * 10 + 48; fputc(ch, fp); for (i = 0; i < 5; i++) { ch = ' '; fputc(ch, fp); } ch = s->sx / 10 + 48; fputc(ch, fp); ch = s->sx - (s->sx / 10) * 10 + 48; fputc(ch, fp); for (i = 0; i < 5; i++) { ch = ' '; fputc(ch, fp); } ch = s->yy / 10 + 48; fputc(ch, fp); ch = s->yy - (s->yy / 10) * 10 + 48; fputc(ch, fp); s = s->next; } else s = s->next; } fclose(fp); printf("生成成功!现在你可以在C盘根目录下看到一个cj4.txt文件"); printf("\n\n"); s = p->next;//将学生信息从链表复制到数组中 for (i = 0; i < 10; i++) { st[i].no = s->no; st[i].yw = s->yw; st[i].sx = s->sx; st[i].total = s->yw + s->sx + s->yy; for (j = 0; j < 7; j++) st[i].name[j] = s->name[j]; s = s->next; } printf("用直接插入法排序请按'':"); scanf("%d", &i); printf("\n\n"); if (i == 1) { for (i = 1; i < 10; i++)//直接插入法排序 { tmp = st[i]; j = i - 1; while (j >= 0 && tmp.total > st[j].total) { st[j + 1] = st[j]; j--; } st[j + 1] = tmp; } printf(" 直接插入法排序后总分从大到小排序为\n"); printf("\n\n"); printf("姓 名 学号 语文 数学 英语 总分\n"); for (i = 0; i < 10; i++) { if (st[i].no < 10) { printf("%s ", st[i].name); printf("%d", 0); printf("%d ", st[i].no); printf("%d ", st[i].yw); printf("%d ", st[i].sx); printf("%d ", st[i].total - st[i].yw - st[i].sx); printf("%d\n", st[i].total); printf("\n"); } else { printf("%s ", st[i].name); printf("%d ", st[i].no); printf("%d ", st[i].yw); printf("%d ", st[i].sx); printf("%d ", st[i].total - st[i].yw - st[i].sx); printf("%d\n", st[i].total); printf("\n"); } } } printf("将排好序的数组打乱\n"); printf("\n"); s = p->next;//将排好序的数组打乱,从新用冒泡法排序 for (i = 0; i < 10; i++) { st[i].no = s->no; st[i].yw = s->yw; st[i].sx = s->sx; st[i].total = s->yw + s->sx + s->yy; for (j = 0; j < 7; j++) st[i].name[j] = s->name[j]; s = s->next; } printf("用冒泡法排序请按'':"); scanf("%d", &i); printf("\n\n"); if (i == 1) { for (i = 0; i < 9; i++)//冒泡法排序 { for (j = 9; j > i; j--) if (st[j].total > st[j - 1].total) { tmp = st[j]; st[j] = st[j - 1]; st[j - 1] = tmp; } } printf(" 冒泡法排序后总分从大到小排序为\n"); printf("\n\n"); printf("姓 名 学号 语文 数学 英语 总分\n"); for (i = 0; i < 10; i++) { if (st[i].no < 10) { printf("%s ", st[i].name); printf("%d", 0); printf("%d ", st[i].no); printf("%d ", st[i].yw); printf("%d ", st[i].sx); printf("%d ", st[i].total - st[i].yw - st[i].sx); printf("%d\n", st[i].total); printf("\n"); } else { printf("%s ", st[i].name); printf("%d ", st[i].no); printf("%d ", st[i].yw); printf("%d ", st[i].sx); printf("%d ", st[i].total - st[i].yw - st[i].sx); printf("%d\n", st[i].total); printf("\n"); } } } printf("\n"); printf("请输入你要查找的学生姓名:(注意:如果名字为两个字,则中间用两个空格!)\n"); do { x = 1; if (i == 1) printf("输入姓名:"); getchar(); for (i = 0; i < 7; i++) sname[i] = getchar(); for (i = 0; i < 10; i++)//在数组中顺序查找 { for (j = 0; st[i].name[j] == sname[j]; j++) {} if (j == 6) { printf(" 数组中查找结果"); printf("\n\n"); printf("姓 名 学号 语文 数学 英语 总分\n"); printf("%s", st[i].name); printf(" %d", st[i].no); printf(" %d", st[i].yw); printf(" %d", st[i].sx); printf(" %d", st[i].total - st[i].yw - st[i].sx); printf(" %d\n\n", st[i].total); x = 0; } } if (x != 0) printf(" 查无此人!\n"); s = p->next; while (s != NULL)//在链表中顺序查找 { for (i = 0; s->name[i] == sname[i]; i++) {} if (i == 6) { printf(" 链表中查找结果"); printf("\n\n"); printf("姓 名 学号 语文 数学 英语 总分\n"); printf("%s", s->name); printf(" %d", s->no); printf(" %d", s->yw); printf(" %d", s->sx); printf(" %d", s->yy); printf(" %d\n\n", s->yw + s->sx + s->yy); x = 0; } s = s->next; } if (x != 0) printf(" 查无此人!\n"); i = 0; printf("继续查找请按''"); scanf("%d", &i); } while (i == 1); printf("\n\n"); printf("-----------------------------谢谢使用!--------------------------------\n\n"); } 请问如何解决索引超出了数组的范围这一问题 现有学生成绩信息文件1(1.txt),内容如下 姓名 学号 语文 数学 英语 张明明 01 67 78 82 李成友 02 78 91 88 张辉灿 03 68 82 56 王露 04 56 45 77 陈东明 05 67 38 47 学生成绩信息文件2(2.txt),内容如下: 姓名 学号 语文 数学 英语 陈果 31 57 68 82 李华明 32 88 90 68 张明东 33 48 42 56 李明国 34 50 45 87 陈道亮 35 47 58 77 …. .. .. .. … ![图片说明](https://img-ask.csdn.net/upload/201912/22/1577019414_694126.png)
救救孩子吧,用requests+re爬取彩虹岛主页信息
我刚学几天python,我也不会啊, 求源代码 简单的就可以,能把彩虹岛游戏官网主页爬取出来 运行成功就可以 谢谢您![图片说明](https://img-ask.csdn.net/upload/201912/19/1576716300_895031.jpg)![图片说明](https://img-ask.csdn.net/upload/201912/19/1576716307_626097.jpg) 救一救孩子吧,挂科了要 谢谢您。
单片机,倒计时,时钟设计,c语言编程
求单片机,倒计时,时钟设计,c语言编程的程序和原理图。大佬们快救救我吧,我找崩溃了
救救孩子吧!http get方法传俩个参数报错。
![图片说明](https://img-ask.csdn.net/upload/201912/26/1577330126_361661.png) 如图所示,输入以上URL时报错。服务器上的代码为 ``` [RoutePrefix("api/WorkflowNodeList")] public class WorkflowNodeListController : ApiController { private hlxEntities db = new hlxEntities(); [ResponseType(typeof(WorkflowNodeList))] // GET api/<controller> [HttpGet] public IHttpActionResult Getnodelist(string model,string key) { WorkflowNodeList nodeList = db.WorkflowNodeList.Where(q => q.model_id == int.Parse(model) & q.key_str == key).SingleOrDefault(); if (nodeList == null) { return NotFound(); } return Ok(nodeList); } ``` ![图片说明](https://img-ask.csdn.net/upload/201912/26/1577330399_820884.png) 整个controller就这一个get方法就很迷,我该怎么才能获得我想要的返回值呢? ``` namespace hlx_service { public static class WebApiConfig { public static void Register(HttpConfiguration config) { // Web API configuration and services config.Formatters.Clear(); config.Formatters.Add(new JsonMediaTypeFormatter()); //.var jsonFormatter = new JsonMediaTypeFormatter(); //config.Services.Replace(typeof(IContentNegotiator), new JsonContentNegotiator(jsonFormatter)); // Web API routes config.MapHttpAttributeRoutes(); config.Routes.MapHttpRoute( name: "DefaultApi", routeTemplate: "api/{controller}/{id}", defaults: new { id = RouteParameter.Optional } ); } } } ``` config 里是这样的。
遗传算法求助!!救救可怜的孩子吧。
![图片说明](https://img-ask.csdn.net/upload/201912/07/1575726004_924232.png) 要求写出遗传算法的设计方案,包括遗传算子和运行参数,要求小数点后精确至少7位。编写程序实现该函数最大值求解。救救可怜的孩子吧!!!
有大神知道dump1090 解码器中的调试模式得到IQ数据幅度图以及IQ数据怎么查看吗?救救孩子吧!
在终端下载DUMP1090之后,想要得到IQ数据的图,按照调试模式J的命令,怎么得到图呢?怎么加载那个文件?![图片说明](https://img-ask.csdn.net/upload/202001/08/1578483392_212838.png)
mapoutput.c:(.data+0x0): multiple definition of `p',这个问题怎么解决啊?
我这个蔡鸡初学者在尝试写一个推箱子的程序,但是今天编译的时候遇到了标题所显示的问题.了一下,是'p'这个指针被多次声明,但是我检查了很多遍(很有可能我太菜.......),应该不会有什么被多次声明什么的,但是它确实......,希望大家帮我康康(编译器用的是DEV c++) 附上代码 main,c ``` #include <stdio.h> #include "maps.h" #include "head.h" int main() { player.a=1; player.b=8; int x=0,y=0,level=114514,z=0; change:scanf_s("%d",&level); level--; system("cls"); while(z==0){ mapoutput(x,y,level,map); int mov; scanf_s("%d",&mov); move(mov,level,map,&player); system("cls"); z=judgement(level,map); if(z==1){ z=0; goto change; } } return 0; } ``` move.c(太多了,省略一些,如果需要的话我在发出来,实在不行我发源文件) ``` #include <stdio.h> #include "head.h" #include "maps.h" void move(int mov,int level,int map[2][6][10],struct post *p){ .............. } ``` judgement.c(同上) ``` #include <stdio.h> #include "head.h" #include "maps.h" int judgement(int level,int map[2][6][10]){ ........... return z; } ``` 然后是两个头文件 map.h ``` #ifndef LIST_HEAD2 #define LIST_HEAD2 int map[2][6][10]={ ........ }; #endif ``` head.h(感觉问题出在这里,但是....) ``` #ifndef LIST_HEAD1 #define LIST_HEAD1 struct post { int x; int y; }player; struct post *p=&player; void mapoutput(int x,int y,int level,int map[2][6][10]); void move(int mov,int level,int map[2][6][10],struct post *p); int judgement(int level,int map[2][6][10]); #endif ``` 然后是运行的报错 ![图片说明](https://img-ask.csdn.net/upload/202002/12/1581489321_528436.png) 希望大佬们能帮我看看问题出在哪里了 //救救孩子,秋梨膏
救救孩子吧 求用C设计一个自动生成四则运算试题的程序
我想了一天也没弄出来 我太难了 1)自动生成10道100以内的2个操作数的四则运算算式(+ - * /),要求运算结果也在100以内 (2)剔除重复算式。 2 + 3 = 和 2 + 3 = 是重复算式 2 + 3 = 和 3 + 2 = 不属于重复算式 (3)题目数量可定制 (4)相关参数可控制 是否包含乘法和除法 操作数数值范围可控(如操作数 在100以内 还是1000以内) 操作数是否含负数     (5)生成的运算题存储到外部文件result.txt中
关于Android studio同步时的异常问题(同步时出现的问题,这该怎么解决。已经两周了。救救孩子吧)
``` ERROR: Unable to resolve dependency for ':app@debugAndroidTest/compileClasspath': Could not download junit.jar (junit:junit:4.12) Show Details Affected Modules: app ERROR: Unable to resolve dependency for ':app@debugAndroidTest/compileClasspath': Could not download hamcrest-integration.jar (org.hamcrest:hamcrest-integration:1.3) Show Details Affected Modules: app ERROR: Unable to resolve dependency for ':app@debugAndroidTest/compileClasspath': Could not download hamcrest-library.jar (org.hamcrest:hamcrest-library:1.3) Show Details Affected Modules: app ERROR: Unable to resolve dependency for ':app@debugAndroidTest/compileClasspath': Could not download hamcrest-core.jar (org.hamcrest:hamcrest-core:1.3) Show Details Affected Modules: app ERROR: Unable to resolve dependency for ':app@debugAndroidTest/compileClasspath': Could not download javawriter.jar (com.squareup:javawriter:2.1.1) Show Details Affected Modules: app ERROR: Unable to resolve dependency for ':app@debugAndroidTest/compileClasspath': Could not download jsr305.jar (com.google.code.findbugs:jsr305:2.0.1) Show Details Affected Modules: app ERROR: Unable to resolve dependency for ':app@debugUnitTest/compileClasspath': Could not download junit.jar (junit:junit:4.12) Show Details Affected Modules: app ERROR: Unable to resolve dependency for ':app@debugUnitTest/compileClasspath': Could not download hamcrest-core.jar (org.hamcrest:hamcrest-core:1.3) Show Details Affected Modules: app ```
Java数据结构解决简单病人就医管理系统
目的: (1)​熟练掌握队列的两种存储方式。 (2)​掌握队列的基本操作及应用。 (3) 利用队列实现病人就医管理模拟程序。 内容: 【问题描述】 设计一个病人就医管理系统 【基本要求】 编写一个程序定义行医类,反映病人到医院看病,排队看医生的情况,在病人排队过程中,主要发生两件事: (1) 病人到达诊室,将病历本交给护士,排到等待队列中候诊。 (2) 护士从等待队列中取出一位病人的病历,该病人进入诊室就诊。 要求程序采用菜单方式,其选项及功能说明如下: (1) 排队------输入病人的病历号,加入到病人排队队列中 (2) 就诊-------病人排队队列中最前面的病人就诊,并将其从队列中删除。 (3) 查看排队------从队首到队尾列出所有的排队病人的病历号。 (4) 下班---------退出运行。 看到很多大神用c++编写这个程序,急需Java版本,求大神救救孩子!!
救救孩子吧刚学数据结构,最后一处错在那里呀?
![图片说明](https://img-ask.csdn.net/upload/201910/20/1571578075_693122.jpg)![图片说明](https://img-ask.csdn.net/upload/201910/20/1571578084_82831.jpg)![图片说明](https://img-ask.csdn.net/upload/201910/20/1571578093_940278.jpg)![图片说明](https://img-ask.csdn.net/upload/201910/20/1571578132_31143.jpg)
用python设计希望被大神看见救救孩子,希望大家踊跃留言,发发爱心。
小型商品管理系统 设计一一个能对商品进行录入、增加、删除、修改、查询等操作的系统。该程序应该具有下列功能: (1)通过键盘输入商品信息,包括编号、类别、名称、价格、折扣比例、生产时间、存货数量等; (2) 增加、删除、修改信息; (3)能按照多种方式查询(至少两种,如编号、类别、名称等) ; 4)统计功能。按类别统计各种商品的存货数量,平均价格及存货量最多的商品信息;(5)排序; (6)输出; 只(7)数据使用文件存放。第7题工资管理系统
c语言迷宫问题怎么解??
系统给出一个12×12的迷宫,编写一个递归函数来穿越迷宫,使用一个简单的算法,即将右手放在墙上,然后开始前进,最终必然会找到出口。 请编写递归函数来穿越迷宫,这个函数将接受一个表示迷宫的12×12的数组作为实参,由于该函数在迷宫中试图找到出口,所以函数将字符放在行走路线经过的空格上每次移动后,函数将显示迷宫的状态。 用#表示墙,用。表示路。 急求!!!有大佬能给一下函数的代码吗???实在不知道怎么写了,救救孩子!!!
Django执行python manage.py makemigrations 报错,数据库是postgresql,大神救救孩子
Traceback (most recent call last): File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\backends\base\base.py", line 220, in ensure_connection self.connect() File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\utils\asyncio.py", line 26, in inner return func(*args, **kwargs) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\backends\base\base.py", line 197, in connect self.connection = self.get_new_connection(conn_params) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\utils\asyncio.py", line 26, in inner return func(*args, **kwargs) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\backends\postgresql\base.py", line 185, in get_new_connection connection = Database.connect(**conn_params) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\psycopg2\__init__.py", line 126, in connect conn = _connect(dsn, connection_factory=connection_factory, **kwasync) psycopg2.OperationalError The above exception was the direct cause of the following exception: Traceback (most recent call last): File "manage.py", line 21, in <module> main() File "manage.py", line 17, in main execute_from_command_line(sys.argv) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\core\management\__init__.py", line 401, in execute_from_command_line utility.execute() File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\core\management\__init__.py", line 395, in execute self.fetch_command(subcommand).run_from_argv(self.argv) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\core\management\base.py", line 328, in run_from_argv self.execute(*args, **cmd_options) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\core\management\base.py", line 369, in execute output = self.handle(*args, **options) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\core\management\base.py", line 83, in wrapped res = handle_func(*args, **kwargs) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\core\management\commands\makemigrations.py", line 101, in handle loader.check_consistent_history(connection) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\migrations\loader.py", line 283, in check_consistent_history applied = recorder.applied_migrations() File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\migrations\recorder.py", line 76, in applied_migrations if self.has_table(): File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\migrations\recorder.py", line 56, in has_table return self.Migration._meta.db_table in self.connection.introspection.table_names(self.connection.cursor()) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\utils\asyncio.py", line 26, in inner return func(*args, **kwargs) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\backends\base\base.py", line 260, in cursor return self._cursor() File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\backends\base\base.py", line 236, in _cursor self.ensure_connection() File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\utils\asyncio.py", line 26, in inner return func(*args, **kwargs) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\backends\base\base.py", line 220, in ensure_connection self.connect() File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\utils.py", line 90, in __exit__ raise dj_exc_value.with_traceback(traceback) from exc_value File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\backends\base\base.py", line 220, in ensure_connection self.connect() File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\utils\asyncio.py", line 26, in inner return func(*args, **kwargs) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\backends\base\base.py", line 197, in connect self.connection = self.get_new_connection(conn_params) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\utils\asyncio.py", line 26, in inner return func(*args, **kwargs) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\django\db\backends\postgresql\base.py", line 185, in get_new_connection connection = Database.connect(**conn_params) File "D:\Program Files (x86)\Microsoft Visual Studio\Shared\Python37_64\lib\site-packages\psycopg2\__init__.py", line 126, in connect conn = _connect(dsn, connection_factory=connection_factory, **kwasync) django.db.utils.OperationalError
从客户端(...)中检测到有潜在危险的Request.Form 值
![图片说明](https://img-ask.csdn.net/upload/201911/22/1574404626_401956.png) 什么玩意,照着其他教程说了加了一段代码还是没用呢 话说html是什么,我用c语言写的为什么还有呢 救救孩子吧。。。 话说按照上面提示怎么搞啊 大声bb:老师的系统真tm垃圾
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
阿里面试官问我:如何设计秒杀系统?我的回答让他比起大拇指
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图和个人联系方式,欢迎Star和指教 前言 Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸,打败了...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n...
面试官问我:什么是消息队列?什么场景需要他?用了会出现什么问题?
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Android性能优化(4):UI渲染机制以及优化
文章目录1. 渲染机制分析1.1 渲染机制1.2 卡顿现象1.3 内存抖动2. 渲染优化方式2.1 过度绘制优化2.1.1 Show GPU overdraw2.1.2 Profile GPU Rendering2.2 卡顿优化2.2.1 SysTrace2.2.2 TraceView 在从Android 6.0源码的角度剖析View的绘制原理一文中,我们了解到View的绘制流程有三个步骤,即m...
微服务中的Kafka与Micronaut
今天,我们将通过Apache Kafka主题构建一些彼此异步通信的微服务。我们使用Micronaut框架,它为与Kafka集成提供专门的库。让我们简要介绍一下示例系统的体系结构。我们有四个微型服务:订单服务,行程服务,司机服务和乘客服务。这些应用程序的实现非常简单。它们都有内存存储,并连接到同一个Kafka实例。 我们系统的主要目标是为客户安排行程。订单服务应用程序还充当网关。它接收来自客户的请求...
致 Python 初学者们!
作者| 许向武 责编 | 屠敏 出品 | CSDN 博客 前言 在 Python 进阶的过程中,相信很多同学应该大致上学习了很多 Python 的基础知识,也正在努力成长。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 Python 这门编程语言,从2009年开始单一使用 Python 应对所有的开发工作,直至今...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip installselenium -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ ...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca...
SpringBoot2.x系列教程(三十六)SpringBoot之Tomcat配置
Spring Boot默认内嵌的Tomcat为Servlet容器,关于Tomcat的所有属性都在ServerProperties配置类中。同时,也可以实现一些接口来自定义内嵌Servlet容器和内嵌Tomcat等的配置。 关于此配置,网络上有大量的资料,但都是基于SpringBoot1.5.x版本,并不适合当前最新版本。本文将带大家了解一下最新版本的使用。 ServerProperties的部分源...
Python绘图,圣诞树,花,爱心 | Turtle篇
每周每日,分享Python实战代码,入门资料,进阶资料,基础语法,爬虫,数据分析,web网站,机器学习,深度学习等等。 公众号回复【进群】沟通交流吧,QQ扫码进群学习吧 微信群 QQ群 1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle()...
作为一个程序员,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、列名...
听说想当黑客的都玩过这个Monyer游戏(1~14攻略)
第零关 进入传送门开始第0关(游戏链接) 请点击链接进入第1关: 连接在左边→ ←连接在右边 看不到啊。。。。(只能看到一堆大佬做完的留名,也能看到菜鸡的我,在后面~~) 直接fn+f12吧 &lt;span&gt;连接在左边→&lt;/span&gt; &lt;a href="first.php"&gt;&lt;/a&gt; &lt;span&gt;←连接在右边&lt;/span&gt; o...
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ...... ...
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!...
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学...
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合...
爬取薅羊毛网站百度云资源
这是疫情期间无聊做的爬虫, 去获取暂时用不上的教程 import threading import time import pandas as pd import requests import re from threading import Thread, Lock # import urllib.request as request # req=urllib.request.Requ...
如何优雅地打印一个Java对象?
你好呀,我是沉默王二,一个和黄家驹一样身高,和刘德华一样颜值的程序员。虽然已经写了十多年的 Java 代码,但仍然觉得自己是个菜鸟(请允许我惭愧一下)。 在一个月黑风高的夜晚,我思前想后,觉得再也不能这么蹉跎下去了。于是痛下决心,准备通过输出的方式倒逼输入,以此来修炼自己的内功,从而进阶成为一名真正意义上的大神。与此同时,希望这些文章能够帮助到更多的读者,让大家在学习的路上不再寂寞、空虚和冷。 ...
雷火神山直播超两亿,Web播放器事件监听是怎么实现的?
Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播。在视频业务大数据平台中,播放数据的统计分析非常重要,所以Web播放器在使用过程中,需要对其内部的数据进行收集并上报至服务端,此时,就需要对发生在其内部的一些播放行为进行事件监听。 那么Web播放器事件监听是怎么实现的呢? 01 监听事件明细表 名...
3万字总结,Mysql优化之精髓
本文知识点较多,篇幅较长,请耐心学习 MySQL已经成为时下关系型数据库产品的中坚力量,备受互联网大厂的青睐,出门面试想进BAT,想拿高工资,不会点MySQL优化知识,拿offer的成功率会大大下降。 为什么要优化 系统的吞吐量瓶颈往往出现在数据库的访问速度上 随着应用程序的运行,数据库的中的数据会越来越多,处理时间会相应变慢 数据是存放在磁盘上的,读写速度无法和内存相比 如何优化 设计...
HTML5适合的情人节礼物有纪念日期功能
前言 利用HTML5,css,js实现爱心树 以及 纪念日期的功能 网页有播放音乐功能 以及打字倾诉感情的画面,非常适合情人节送给女朋友 具体的HTML代码 具体只要修改代码里面的男某某和女某某 文字段也可自行修改,还有代码下半部分的JS代码需要修改一下起始日期 注意月份为0~11月 也就是月份需要减一。 当然只有一部分HTML和JS代码不够运行的,文章最下面还附加了完整代码的下载地址 &lt;!...
Python新型冠状病毒疫情数据自动爬取+统计+发送报告+数据屏幕(三)发送篇
今天介绍的项目是使用 Itchat 发送统计报告 项目功能设计: 定时爬取疫情数据存入Mysql 进行数据分析制作疫情报告 使用itchat给亲人朋友发送分析报告 基于Django做数据屏幕 使用Tableau做数据分析 来看看最终效果 目前已经完成,预计2月12日前更新 使用 itchat 发送数据统计报告 itchat 是一个基于 web微信的一个框架,但微信官方并不允许使用这...
相关热词 c# 压缩图片好麻烦 c#计算数组中的平均值 c#获取路由参数 c#日期精确到分钟 c#自定义异常必须继承 c#查表并返回值 c# 动态 表达式树 c# 监控方法耗时 c# listbox c#chart显示滚动条
立即提问