首页 > 其他分享 >C语言练习题--一维、二维字符串数组

C语言练习题--一维、二维字符串数组

时间:2024-09-08 17:20:24浏览次数:17  
标签:练习题 -- C语言 char int 数组 printf 字符串 include

1.下列对 C 语言字符数组的描述中错误的是 ( D) 

A. 字符数组可以存放字符串

B. 字符数组中的字符串可以整体输入、输出

C. 不可以用关系运算符对字符数组中的字符串进行比较

D. 可以在赋值语句中通过赋值运算符 "=" 对字符数组整体赋值

分析:D只能逐个字符进行复制或者利用字符串处理函数(strcpy函数等)

2.下列描述中不正确的是( C)

A.字符型数组中可以存放字符串

B.可以对字符型数组进行整体输入、输出

C.可以对整型数组进行整体输入、输出

D.不能在赋值语句中通过赋值运算符"="对字符型数组进行整体赋值

分析:整型数组输出只能用循环进行逐个元素的输入、输出

3.下列代码片段执行的结果是:C

char szTest[] = "ABCDEF";

strncpy(szTest, szTest, 4);

printf("%s", szTest);

  1. ABCD          B. ABCDE                 C. ABCDEF               D. 以上都不对

分析:因为只复制了ABCD四个字符,未复制空字节,字符串复制后不会以空结束,直到原本字符串结尾的空字节为止

4.以下对字符数组test 赋值方式错误的是(B )。 

A. char test[10]; strcpy(test, "test");

B. char test[10]; test="test";

C. char test[]={'t', 'e', 's', 't’};

D. char test[10]={'t', 'e', 's', ‘t’};

分析:原因如第一题,不能用赋值运算符给字符串数组整体赋值

5.以下语句不能正确赋值的是( D) 

A. char *s = "China";

B. char s3[20] = "China";

C. char s2[]={'C', 'h', 'i', 'n', 'a'};

D. char s1[10]; s1="China";

分析:原因同上题

6.以下程序运行后输出结果是(A )

main()

{

   char ch[2][5] = {"693", "825"}, p[2][5];

   int i, j, s = 0;

   for(i=0;i<2;i++) p[i]=ch[i];

    for(i=0;i<2;i++)

            for(j=0;p[i][j]>='0' && p[i][j]<='9';j+=2)

                s=10*s+p[i][j]-'0';   6 3 8 5

    printf("%d\n", s);

}

A.6385   B. 33        C. 693825        D. 22

分析:第一个for循环将字符串数组ch每一行赋值给p字符串数组;第二个for循环遍历p数组每一行,第三个for循环遍历p每一个数组下标为偶数并且是数字字符的元素,将其转换成整型数值并累加给s

7.为了比较两个字符串s1和s2是否相等,应当使用(D )

A. if(s1 = s2)                                       B. if(s1==s2)

C. if(strcmp(&s1, &s2)==0)             D. if(strcmp(s1, s2)==0)

分析:strcmp函数为比较字符串函数,用法是strcmp(char a[],char b[]),结果分三种,大于零字符串a大,等于零a与b字符串相等,小于零a字符串小

二、程序编写

1.编写一个程序。输入一个字符串,将其逆序后输出?

代码如下:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main(int argc, const char *argv[])
{
	char a[100];
	printf("请输入一个字符串:");
	scanf("%s",a);
    //定义一个变量存放头下标
	int i=0;
    //定义一个变量存放尾下标
    //strlen函数求字符串长度
	int j=strlen(a)-1;
    //从头尾向中间循环
    //如果头下标小于尾下标
    //交换两头字符
	while(i<j){
		char t=a[i];
		a[i]=a[j];
		a[j]=t;
		i++;
		j--;

	}
	printf("逆序后的字符串为:%s\n",a);
	return 0;
}

运行结果如图所示:

2.编写一个程序。负责将一个字符串拷贝到另一个字符串,不调用 C++/C 的字符串库函数。

代码如下:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main(int argc, const char *argv[])
{
    //定义两个字符串数组
	char a[100];
	char b[100];
	printf("请输入两个字符串:");
	scanf("%s%s",a,b);
	int i=0;
    //元素不为\0继续循环
    //将b数组元素拷贝给a
	while(b[i]!='\0'){
		a[i]=b[i];
		i++;
	}
    //手动添加\0
	a[i]='\0';
	printf("a=%s b=%s\n",a,b);
	return 0;
}

运行结果如图所示:

3.编写一个程序。不使用字符串连接函数strcat,实现两个字符串的链接 。

代码如下:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main(int argc, const char *argv[])
{
	char a[100],b[100];
	printf("请输入两个字符串:");
	scanf("%s%s",a,b);
	int i=0;
    //获取字符串长度
	int j=strlen(a);
    //将b数组元素赋值给a
	while(b[i]!='\0'){
		a[j+i]=b[i];
		i++;
	}
	a[j+i]='\0';
	printf("链接后字符串为:%s\n",a);
	return 0;
}

运行结果如图所示:

4.编写一个程序。请实现输入一个字符串,这个字符串字符串包含一个或多个数字,把这些数字字符转换为整数,如果字符串参数包含了非数字字符,置零,不必担心算数溢出。

输入:123abc456

输出:printf(“%d\n” , num);  num=123000456

代码如下:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main(int argc, const char *argv[])
{
	char a[100];
	printf("请输入一个字符串:");
	scanf("%s",a);
	int len=strlen(a);
	int sum=0;
    //遍历字符串数组
	for(int i=0;i<len;i++){
        //如果字符串元素为非数字字符,则将其置零
		if(!(a[i]>='0'&&a[i]<='9'))
			a[i]='0';
		    //将数字字符转换成整型并累加到sum中
            sum=sum*10+a[i]-'0';
	}
	printf("输出整数为:%d\n",sum);
	return 0;
}

运行结果如图所示:

5.编写一个程序。实现输入N个字符串,输出这N个字符串中的最大字符串和最长字符串,可以调用字符串处理函数。

代码如下:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main(int argc, const char *argv[])
{
	int n=0;
	printf("要输入几个字符串:");
	scanf("%d",&n);
	char a[n][100];
	printf("请输入字符串:");
	for(int i=0;i<n;i++){
		scanf("%s",a[i]);
	}
	char max[100];
	char longest[100];
    //将a[0]数组元素先赋给max和longest
    //二维字符串数组赋值要用strcpy函数
	strcpy(max,a[0]);
	strcpy(longest,a[0]);
    //for循环遍历数组将最大字符串复制给max
    //最长字符串复制给longest
	for(int i=0;i<n;i++){
		if(strcmp(a[i],max)>0){
			strcpy(max,a[i]);
		}
		if(strlen(longest)<strlen(a[i]))
			strcpy(longest,a[i]);
	}
	printf("最大字符串为:%s 最长字符串为:%s\n",max,longest);
	return 0;
}

运行结果如图所示:

标签:练习题,--,C语言,char,int,数组,printf,字符串,include
From: https://blog.csdn.net/KBDYD1010/article/details/141966824

相关文章

  • 小猪佩奇学英语——第五天——hide and seek
    例句hideandseek,捉迷藏seek,寻找find,找到了ItisGeorge'sturntohide.It'sourturn.用is是因为虽然我们是2个以上的人,但是我们是一组,轮到我们的只有一轮,所以是单数。It'syourturn.轮到你们了It'stheriturn.轮到他们了。It'ssb'sturnto..........
  • LOJ4218 「IOI2024」尼罗河船运 题解
    题目描述有\(n\)件手工艺品,第\(i\)件重量为\(w_i\),有参数\(a_i\)和\(b_i\)。每艘船最多可以运输两件手工艺品:如果只运输第\(i\)件,重量没有要求,代价为\(a_i\)。如果同时运输第\(i\)和第\(j\)件,要求\(|w_i-w_j|\leD\),代价\(b_i+b_j\)。\(q\)次询问,给......
  • Einstein 大战 Eisenstein 大战 Eppstein
    \[\newcommand{\Co}{\operatornameC}\newcommand{\Am}{\operatornameA}\newcommand{\Vo}{\operatornameV}\newcommand{\Me}{\operatornamem}\newcommand{\Se}{\operatornames}\newcommand{\Ne}{\operatornameN}\newcommand{\Fa}{\operatorn......
  • 51nod 石子分配
    可以发现步数限制把数轴变为了环。环之间不可以交换,环内相邻两点可以交换,然后我们只需要对每个环操作,最后累加。对于环上的每个石子堆,我们需要将其石子数调整到均值\(avg\)。因此,我们首先计算每个堆石子相对于\(avg\)的偏差,即\(nowa[i]-avg\)。因为相邻节点不一定能凑齐......
  • csp-s模拟1
    A.喜剧的迷人之处在于切入点在\(a\),考虑\(a\)是不是完全平方数,是的话直接找最小能匹配的完全平方数即可,不是的话\(a\)一定可以表示成\(kx^2\)的形式,倒着找到最大的平方因子除去,只需要在\(L\)~\(R\)间找到一个最小的数也等于\(kx^2\)即可点击查看代码#include<bits......
  • 实现人形角色的攀爬
    在Unity实现角色攀爬前言开放世界类型的游戏近年也热门起来了,自由攀爬也成了这一类游戏的一大特色。攀爬给了玩家更多探索路径的选择,也让地图设计有了更多思路。这次,我们就来尝试在Unity中制作一个人形角色的攀爬。注:攀爬是一个角色完整动作系统的一部分,本文暂且抛开其它动......
  • LVDS(FPGA)
    差分输入时钟缓冲器(IBUFDS)点击查看代码//IBUFDS:DifferentialInputBuffer//7Series//XilinxHDLLanguageTemplate,version2024.1IBUFDS#(.DIFF_TERM("FALSE"),//DifferentialTermination.IBUF_LOW_PWR("TRUE"),/......