教你夺冠


私信TA

用户名:835685327

访问量:156772

签 名:

相互交流 相互学习

等  级
排  名 15
经  验 22543
参赛次数 0
文章发表 84
年  龄 0
在职情况 学生
学  校 辣鸡施工大学
专  业

  自我简介:

努力刷题 熟能生巧!

这道题目我的思路如下:

1) 定义一个字符指针数组,用来存放将要输入的各个字符串的指针(用动态内存分配开辟空间存放数组)

2) 遍历这个字符指针数组,前N行字符串原样输出

3) 余下的字符串以空格或回车分割依次按行输出


该程序几处需要注意的地方:

1、因为我习惯用scanf("%[^\n]", strtmp)输入字符串的方式,所以在输入最开始的正整数N之后的回车换行符和接下来每次输入一个字符串后的回车换行符都得使用getchar函数吃掉,要不然会出现错误!

2、在思路3)中我使用了这个技巧:while ((c = *(inputstr[index]++)) != '\0')。即通过指针的方式获取这个字符串对应的每个字符,碰到结束符'\0'才结束循环,当c为空格符时,就连续输入两个换行符,当c不是空格符时直接输出。

    

参考代码:

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

int main(void)
{
    int N;
    scanf("%d", &N);
    if (N > 100) //输入的N最多为100 超过则直接退出
    {
        return -1;
    }
    getchar(); //吃掉上面输入中回车符给下面输入字符串带来的影响

    char *inputstr[N + N]; //定义一个字符指针数组,用来存放将要输入的各个字符串的指针
    char strtmp[1000];     //strtmp临时变量存放每次输入的字符串
    int i = 0;             //字符指针数组下标

    while (scanf("%[^\n]", strtmp) != EOF)
    {
        getchar(); //吃掉上一个字符串中回车符对下一个字符串输入带来的影响

        //对于每个字符串动态分配空间并拷贝
        int len = strlen(strtmp);
        inputstr[i] = (char*)malloc(len + 1);
        strcpy(inputstr[i], strtmp);
        i++;
    }

    int index = 0;
    for (index = 0; index < i; index++)
    {
        if (index < N) //前N行字符串原样输出
        {
            printf("%s\n", inputstr[index]);
            printf("\n");
        }
        else //余下的字符串以空格或回车分割依次按行输出
        {
            char c;
            while ((c = *(inputstr[index]++)) != '\0')
            {
                if (c == ' ')
                {
                    putchar(' ');
                    printf("\n\n");
                }
                else
                {
                    putchar(c);
                }
            }
        }
    }

    return 0;
}

那么问题来了...

为啥这个程序还是不能通过...一直是答案错误 也是很心累 求大神告知!!

欢迎留言交流!

 

0.0分

29 人评分

  评论区

#include <iostream>
#include <string>
#include <array>
#define MAX 200

using namespace std;

int main()
{
	// define variable
	int N{};
	array<string, MAX> str{};
	// input
	do {
		cin >> N;
	} while (N > 100);
	cin.get();
	for (int i = 0; i < N; i++) {
		getline(cin, str[i]);
	}
	while (cin >> str[N++]) {}
	// output
	for (int i = 0; ; i++) {
		if (str[i] == "\0") {
			break;
		}
		cout << str[i] << endl << endl;
	}
	return 0;
}
用C++写简单点,关键在于输入时以什么为结尾(本题默认EOF),输出时以什么判断条件来终止(输入完毕后,该数组结尾处为"\0",注意因为是字符串型,所以双点)
2022-02-28 22:15:52
输出格式错了而已
2022-01-01 11:46:10
if (index < N) //前N行字符串原样输出
            printf("%s\n\n", inputstr[index]);
        else //余下的字符串以空格或回车分割依次按行输出
        {
            char c;
            while ((c = *(inputstr[index]++)) != '\0')
            {
                if (c == ' ')
                {
                    c = '\n';
                    putchar(10);
                }
                    putchar(c);
            }
            printf("\n\n");
        }
    }
    for(i = 0; i < N; ++i)
        free(inputstr[i]);
    return 0;
}
2022-01-01 11:44:18
#include <stdio.h>
#include <string.h>
#include <malloc.h>
#define M 1000
int main(void)
{
    int N;
    scanf("%d", &N);
    getchar(); //吃掉上面输入中回车符
    char *inputstr[N]; //定义一个字符指针数组,用来存放将要输入的各个字符串的指针
    char strtmp[M];
    int i = 0;
    while(gets(strtmp))   //while (scanf("%[^\n]", strtmp) != EOF)
    {
        //getchar(); //吃掉上一个字符串中回车符对下一个字符串输入带来的影响
        //对于每个字符串动态分配空间并拷贝
        int len = strlen(strtmp);
        inputstr[i] = (char*)malloc(len + 1);
        strcpy(inputstr[i], strtmp);
        i++;
    }
    int index = 0;
    for (index = 0; index < i; index++){
        if (in
2022-01-01 11:41:46
很不错
2022-01-01 11:11:27
长的一批,最后你来个答案错误????
2021-11-22 19:11:15
那如何判断输入结束?
2020-11-18 09:26:45
#include<stdio.h>
int main()
{
    int n,i;
    char a[1001][1001],c;
    scanf("%d",&n);
	c=getchar();
    for(i=0;i<=n;i++)
    gets(a[i]);
    for(i=0;i<n;i++)
    {
        puts(a[i]);
        printf("\n");
    }
    for(i=0;a[n][i];i++)
    {
        if(a[n][i]==' ')
        {
            printf("\n\n");
            continue;
        }
        printf("%c",a[n][i]);
    }
    printf("\n\n");
    return 0;
}我这个为啥一直都是%33的错误呢,求大佬解答!!
2020-02-13 11:38:04