解题思路:
1:输入一个整数n,开辟两次n个字符空间;
2:输入n个字符;(这里默认没有空格等字符)
3:输入一个整数m;
4:求复制的字符个数;
5:把从m开始的字符复制到另一字符串;
6:输出;
代码一(字符没有空格,正确)
#include <stdio.h> #include <string.h> #include <malloc.h> int main() { int n, m, t; scanf( "%d", &n ); char *a, *b; a = (char *) malloc( n * sizeof(char) ); b = (char *) malloc( n * sizeof(char) ); scanf( "%s", a ); scanf( "%d", &m ); t = n - m + 1; for ( int i = 0; i < t; i++ ) { b[i] = a[m - 1]; m++; } printf( "%s", b ); return(0); }
代码二:(字符有空格)
#include <stdio.h> #include <string.h> #include <malloc.h> int main() { int n, m, t; scanf( "%d", &n ); getchar(); char *a, *b; a = (char *) malloc( n * sizeof(char) ); b = (char *) malloc( n * sizeof(char) ); gets( a ); scanf( "%d", &m ); t = n - m + 1; for ( int i = 0; i < t; i++ ) { b[i] = a[m - 1]; m++; } puts( b ); return(0); }
别忘点赞哦-.-
0.0分
58 人评分
#include<stdio.h> #include<string.h> #include<malloc.h> int main() { char *a,*b,k=0,i; int m,n; scanf("%d",&n); a = (char *) malloc( n * sizeof(char) ); b = (char *) malloc( n * sizeof(char) ); scanf("%s",a); scanf("%d",&m); for(i=m-1;i<n;i++) { b[k++]=a[i]; } printf("%s\n",b); return 0; }话说这个程序哪里有问题鸭 输出总会多一个屯
juzi 2019-02-19 10:52:40 |
我也是呢,我也多一个屯。咋回事
juzi 2019-02-19 10:53:59 |
但是提交是正确的!
蔡蔡蔡蔡姬丶 2019-03-29 09:58:09 |
@juzi puts函数输出 是以'\0'为结束判断的,作者只声明n个大小,没有存入\0,puts会出错。可以malloc分配n+1个大小
2957568819 2019-08-12 11:39:52 |
添加b[i]='\0';
给我五美元 2019-09-09 21:10:05 |
添加b[k]='\0';
给我五美元 2019-09-09 21:11:51 |
我想问一下,字符型指针有多大,为什么能够申请比它大的内存空间n*(sizeof(char))
#include<stdio.h> #include<string.h> int main() { int n,m; char str[100]; char ste[100]; scanf("%d",&n); scanf("%s",ste); scanf("%d",&m); int j=0; for(int i=m-1;ste[i]!=0;i++,j++) { str[j]=ste[i]; } //str[j]='\0'; puts(str); }
这样可否?大佬们有什么改进意见没? #include <stdio.h> #include <stdlib.h> void ace(char *p,char *q) { int i; for(i=0;q[i]!='\0';i++) { p[i]=q[i]; } p[i]='\0'; puts(p); } int main() { int n,m; char *p=NULL; char *q=NULL; int i; scanf("%d",&n); getchar();//吸收换行符 p=(char*)malloc((n+1)*sizeof(char)); gets(p); scanf("%d",&m); q=(char*)malloc((n-m+2)*sizeof(char)); for(i=0;i<n-m+1;i++) { q[i]=p[i+m-1]; } ace(p,q); free(p); free(q); return 0; }
getchar()用得好!点赞了。但是有些问题: 1. #include <malloc.h>?不太熟悉这个头文件,是否应该#include <stdlib.h>? 2. b = (char *)malloc( (n-m+2) * sizeof(char) );就足够了? 3. 虽然是算法代码,也不能忘记free?
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:1097 |
妹子杀手的故事 (C语言代码)浏览:739 |
奖学金 (C++代码)浏览:2057 |
C语言程序设计教程(第三版)课后习题6.1 (C语言代码)浏览:545 |
【密码】 (C语言代码)浏览:350 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:1334 |
WU-蓝桥杯算法提高VIP-勾股数 (C++代码)浏览:1686 |
C语言程序设计教程(第三版)课后习题4.9 (C语言代码)浏览:649 |
C语言程序设计教程(第三版)课后习题9.8 (C语言代码)浏览:646 |
2004年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:676 |
给我五美元 2019-09-09 21:21:32 |
取出缓冲区里特殊的空格和\n ;你可以查一下scanf和gets的区别就可以知道了