两段代码有何不同

两段代码究竟有何不同???

给定两个整数A和B,输出从A到B的所有整数以及这些数的和。

输入格式:
输入在一行中给出2个整数A和B,其中−100≤A≤B≤100,其间以空格分隔。

输出格式:
首先顺序输出从A到B的所有整数,每5个数字占一行,每个数字占5个字符宽度,向右对齐。最后在一行中按Sum = X的格式输出全部数字的和X。
1, 自己代码

#include<stdio.h>
int main(void)
{
int a,,b,i,sum;
int count = 0;
scanf("%d %d",&a,&b);
for(i=a;i<=b;i++)
{ 
    printf("%5d",i);
	sum += i;
	count++;
	if(count % 5 == 0)
	printf("\n");
	else if (i == b)
	printf("\n");
	} 
printf("sum = %d",sum);
return 0;
}

2,正确代码

 #include<stdio.h>
 int main()
 {
 int a,b,i,cot=0,sum=0;
 scanf("%d %d",&a,&b);
 for(i=a;i<=b;i++){
    printf("%5d",i);
    cot++;
    if(cot%5==0&&i!=b)
        printf("\n");
        }
   printf("\n");
   for(i=a;i<=b;i++)
    sum+=i;
    printf("Sum = %d",sum);
    return 0;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
分页和分段是两种不同的内存管理方式,它们的主要区别如下: 1. 基本单位不同: 分页的基本单位是页(Page),而页的大小是固定的,通常为4KB或8KB等。每个进程被划分成若干个页,每个页与一个物理帧对应。当进程访问内存时,需要将逻辑地址转换为物理地址,这个过程需要使用页表来完成。 分段的基本单位是段(Segment),每个段的大小可以不同,可以根据进程的需要进行分配。每个进程被划分成若干个段,每个段可以有不同的属性和访问权限。当进程访问内存时,需要将逻辑地址转换为物理地址,这个过程需要使用段表来完成。 2. 存储管理方式不同: 在分页系统中,内存被划分成大小固定的页框,每个页框与一个物理页对应。当进程需要分配内存时,内存管理器会将进程的虚拟地址空间划分成若干个页,然后将这些页映射到物理页框上。 在分段系统中,内存被划分成许多大小不同的段。每个段可以有不同的长度和属性,例如代码段、数据段、栈段等。当进程需要分配内存时,内存管理器会将进程的虚拟地址空间划分成若干个段,然后将这些段映射到内存中的不同位置上。 3. 碎片问题不同: 在分页系统中,由于每个页的大小是固定的,当进程需要分配的内存大小不是页的整数倍时,会产生内部碎片。此外,如果内存中存在很多小的空闲页框,但它们的总大小不足以满足一个进程的需要,会产生外部碎片。 在分段系统中,由于每个段的大小可以根据需要进行分配,可以避免内部碎片的产生。但是,如果进程需要的空间大小不连续,或者多个进程的段大小不连续,就会产生外部碎片。 总之,分页和分段是两种不同的内存管理方式,它们的基本单位、存储管理方式和碎片问题都不同。在选择内存管理方式时,需要根据具体的应用场景进行选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值