1.两数之和

题目:两数之和

给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。 你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。

给定 nums = [2, 7, 11, 15], target = 9

因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]


解题思路:

1.首先想到的是暴力破解,两层循环数组,判断和是否为target。

2.改进,想到用哈希数组,循环两次进行处理,最后再修改成一次。
代码如下:

private int [] twoSum(int[] nums, int target) {
        HashMap<Integer, Integer> map = new HashMap<Integer, Integer>(4);
        int [] sort = new int[2];
        for (int i = 0, j = nums.length; i < j; i++) {
            int k = target - nums[i];
            if (map.get(k) != null) {
                sort[0] = i;
                sort[1] = map.get(k);
                return sort;
            }
            map.put(nums[i], i);
        }
        return null;
    }
不足:

1.第一次使用leetCode训练算法题,选择的是简单的题,虽然解决了,但是使用的时间还是太久,导致踩了很多坑,比如用key来存储下标,value存储值 等等。

2.对数组和集合的使用不够熟练。

3.代码中有可以改进点,例如返回可以改成

return new  int [] {map.get(k), i};
学习:

学习运行时间最短的代码

class Solution {
   int size = 2048;
	int[] map = new int[size];
	int length = 2047;
	int index;
    
    public int[] twoSum(int[] nums, int target) {
    	for (int i = 0; i < nums.length; i++) {
			index = nums[i]&length;

			if (map[index] != 0) {
				return new int[] { map[index] - 1, i };
			} else {
				map[(target - index)&length ] = i + 1;
			}
		}
		throw new IllegalArgumentException("No two sum solution");
    }
}
总结

第一次提交代码,好有成就感,哈哈。还要继续练习,坚持下去,加油!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用以下代码实现: #include <stdio.h> int main() { int a, b, diff; printf("请输入两个整数:\n"); scanf("%d %d", &a, &b); diff = a - b; printf("两数之差为:%d\n", diff); return 0; } ### 回答2: 要用C语言输入两个数并求两数之差,可以使用以下代码实现: ```c #include <stdio.h> int main() { int num1, num2, difference; printf("请输入一个数:"); scanf("%d", &num1); printf("请输入第二个数:"); scanf("%d", &num2); difference = num1 - num2; printf("两数之差为:%d\n", difference); return 0; } ``` 首先,我们声明了三个变量`num1`、`num2`和`difference`,分别用来存储输入的两个数和它们的差。 然后,通过`printf`函数提示用户输入一个数,并通过`scanf`函数将用户输入的值存储到`num1`变量中。接着,再次使用`printf`和`scanf`函数获取并存储第二个数到`num2`变量中。 然后,通过`difference = num1 - num2;`计算两数之差,并将结果存储到`difference`变量中。 最后,使用`printf`函数输出计算得到的差值。 以上就是用C语言输入两个数并求两数之差的实现代码,希望能帮到你。 ### 回答3: 用C语言求两个数的差可以通过以下步骤完成: 1. 首先,需要在程序中引入C语言的输入输出库文件,头文件为<stdio.h>。这样才能使用scanf和printf函数。 2. 在程序的主函数中定义两个变量,用于存储输入的两个数。可以使用int类型来定义这两个变量,如int num1, num2;。 3. 使用scanf函数接收用户的输入。可以通过scanf("%d %d", &num1, &num2);来依次接收并保存用户输入的两个数。 4. 使用一个变量来保存两个数之差,比如定义一个int类型的变量diff。通过计算num1 - num2来得到两个数的差,并将其赋值给diff。 5. 最后,使用printf函数将两个数的差输出到屏幕上。可以使用printf("两数之差为:%d\n", diff);来输出差值。 整个程序的代码如下所示: ```c #include<stdio.h> int main() { int num1, num2, diff; printf("请输入两个数:\n"); scanf("%d %d", &num1, &num2); diff = num1 - num2; printf("两数之差为:%d\n", diff); return 0; } ``` 以上就是用C语言求两个数之差的方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值