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

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

时间:2024-09-08 17:20:24浏览次数:7  
标签:练习题 -- 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

相关文章

  • AI苏格拉底提问学习记录
       ......
  • 小猪佩奇学英语——第五天——hide and seek
    例句hideandseek,捉迷藏seek,寻找find,找到了ItisGeorge'sturntohide.It'sourturn.用is是因为虽然我们是2个以上的人,但是我们是一组,轮到我们的只有一轮,所以是单数。It'syourturn.轮到你们了It'stheriturn.轮到他们了。It'ssb'sturnto..........
  • 小猪佩奇学英语——第六天——The Playgroup
    第六天——ThePlaygroup例句George,areyoulookingforwardtotheplaygroup?乔治,你现在是不是正期待去托儿所。lookforwardtosth期待某物lookforwardtodoing...期待做某事用looking表示正期待....maybeGeorgeistoosmalltogotomyplaygroup?too......
  • Python cheatsheet 速查表
    Python速查表中文版本手册是Pythoncheatsheet的中文翻译版。原作者:ArianneColtonandSeanChen([email protected])编译:ucasFL目录常规数值类类型数据结构函数控制流面向对象编程常见字符串操作异常处理列表、字典以及元组的推导表达式单元测......
  • 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"),/......