期末复习-----4(PTA之前的编程测试题)

#include<stdio.h>
#include<string.h>

struct student{
	char num[6];
	char name[11];
	int a,b,c;
	int sum;
};
int main()
{
	int n;
	int i;
	scanf("%d",&n);
	struct student stu[n],max;
	for(i=0;i<n;i++)
	{
		scanf("%s %s %d %d %d",stu[i].num,stu[i].name,&stu[i].a,&stu[i].b,&stu[i].c);
		stu[i].sum=stu[i].a+stu[i].b+stu[i].c;
		
		
		if(i==0)
		{
			max=stu[i];
		}
		
		if(stu[i].sum>max.sum)
		max=stu[i];
	}
	
	printf("%s %s %d",max.name,max.num,max.sum);
    return 0;
}

存在的问题:

1.怎么样用第一个是总分最高的学生,输出时候不只能输出最高总分,还能对应学生,小杜 if(i==0){max=stu[i]}很好的解决了我的问题

2.循环中要不要加stu[i].还是知己stu,答案是需要加

想要用stu[i].sum,结构体中就必须要加入sum;

想要用max.name,主函数中定义初始化结构体的时候就需要struct student stu[n],max;想、连同max一起定义

找出最长的字符串

#include<stdio.h>
#include<string.h>
int main()
{
	int n;
	scanf("%d",&n);
	char str[80],maxstr[80];
	int len=0,maxlen=0;
	for(int i=0;i<n;i++)
	{
		gets(str);
		len=strlen(str);
		if(len>maxlen)
		{
			maxlen=len;
			strcpy(maxstr,str);
		}
	}
	printf("%s",maxstr);
	return 0;
}

小杜写的:

#include <stdio.h>
#include <string.h>
int main()
{
    int n;
    char p[81],max[81];
    scanf("%d",&n);
    scanf("%s",p);
    strcpy(max,p);
    for(int i=1; i<n; i++)
    {
        scanf("%s",p);
        if(strlen(p)>strlen(max))
            strcpy(max,p);
    }
    printf("The longest is: %s",max);
    return 0;
}
相关推荐
pianmian142 分钟前
python数据结构基础(7)
数据结构·算法
好奇龙猫3 小时前
【学习AI-相关路程-mnist手写数字分类-win-硬件:windows-自我学习AI-实验步骤-全连接神经网络(BPnetwork)-操作流程(3) 】
人工智能·算法
sp_fyf_20243 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-11-01
人工智能·深度学习·神经网络·算法·机器学习·语言模型·数据挖掘
香菜大丸4 小时前
链表的归并排序
数据结构·算法·链表
jrrz08284 小时前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
oliveira-time4 小时前
golang学习2
算法
南宫生5 小时前
贪心算法习题其四【力扣】【算法学习day.21】
学习·算法·leetcode·链表·贪心算法
懒惰才能让科技进步6 小时前
从零学习大模型(十二)-----基于梯度的重要性剪枝(Gradient-based Pruning)
人工智能·深度学习·学习·算法·chatgpt·transformer·剪枝
Ni-Guvara6 小时前
函数对象笔记
c++·算法
泉崎6 小时前
11.7比赛总结
数据结构·算法